@font-face { font-family : name src : url ( url ) sRules }
取值:
name : 字体名称。任何可能的 font-family 属性的值
url ( url ) : 使用绝对或相对 url 地址指定OpenType字体文件
sRules : 样式表定义
说明:
设置嵌入HTML文档的字体。此规则无默认值。
此规则使你能够在网页上使用客户端本地系统上可能没有的字体。 url 地址必须指向 OpenType 字体文件(.eot或.ote)。此文件包含可以转换为 TrueType 字体的压缩字体数据,可以用来提供HTML文档使用该字体,或取代客户端系统已有的同名字体。此文件可以使用 Microsoft WEFT 工具制作。
这样,我们需要微软的WEFT工具来完成。
Microsoft WEFT 工具说明页
http://www.microsoft.com/typography/web/embedding/weft3/
Microsoft WEFT 工具下载地址(点击下载)
http://download.microsoft.com/download/8/a/1/8a1be03f-f7fc-4504-af9a-7b9230775284/WEFTIII2b1.exe
字体嵌入演示
http://www.microsoft.com/typography/web/embedding/demos/10/demo10.htm
使用教程(E文)
http://www.microsoft.com/typography/web/embedding/weft3/tutorial.aspx
简单说明一下: 先新建一个htm空文档,然后打开WEFT,根据向导,添加刚才新建的htm文件
然后下一步,会提示程序将分析系统字体,此时不要勾选skip analysis,继续下一步,等程序扫描完毕,出现一个对话框,此时先不着急下一步,点"Add"按钮,选择一个需要制作的字体,只有TrueType的字体可以被制作,选好后下一步。 接着选择,生成的ETO字体文件的保存位置 下面这个选框比较重要,第一次就是因为没弄清楚,导致无效。这里要输入字体允许被使用在哪些站点内。这个地方建议输入两个域名,一个是:http://127.0.0.1,做为本机测试用,另一个是自己的站点的地址,如:http://www.imagecode.net,设置好后,再下一步直到完成。 这样还不算完,找到生成好的EOT文件,放在网站目录里,在需要使用这个字体的页面里,按照下面的方法操作。
<HTML>
<HEAD>
<TITLE>Test Page</TITLE>
<STYLE TYPE="text/css">
<!--
@font-face {
font-family: myfont
font-style: normal
src: url(ARIAL0.eot)}
-->
</STYLE>
</HEAD>
<BODY>
<FONT FACE="myfont">测试文字</FONT>
</BODY>
</HTML> 最后要注意的是在@font-face的时候,font-family最好自己定义一个字体名称,不要跟本机的字体名称一致。否则在<font face='myfont'>的时候,如果EOT字体加载失败,有可能会使用系统字体来显示,这样自己就无法判断是否CSS字体加载成功。其实,字体是否加载成功,在安装了WEFT后,会自动弹出提示。
字体设置使用 CSS font 属性
定义和用法
font 简写属性在一个声明中设置所有字体属性。
注释:此属性也有第六个值:"line-height",可设置行间距。
说明
这个简写属性用于一次设置元素字体的两个或更多方面。使用 icon 等关键字可以适当地设置元素的字体,使之与用户计算机环境中的某个方面一致。注意,如果没有使用这些关键词,至少要指定字体大小和字体系列。
可以按顺序设置如下属性:
font-style
font-variant
font-weight
font-size/line-height
font-family
可以不设置其中的某个值,比如 font:100% verdana也是允许的。未设置的属性会使用其默认值。
可能的值
拓展:
设置字体可以使用CSS font全部设置。也可以使用font-size、font-family之类的属性进行单独设置。
font-family:"文鼎大黑","微软雅黑"
中文网页一般都只能用:宋体、黑体、微软雅黑等大多数系统上都有的字体,例如上面代码,你电脑上有文鼎大黑字体,并且css设置了字体为:文鼎大黑,但是传到网上,我看你的网页时,我机器没有这个字体,还是白搭,系统会用默认的宋体给我显示。
解决办法:
1.用特殊字体的地方做成图片(ps也好,服务器端程序自动生成也好,都行)
2.字体嵌入到Flash
3.css的@font-face可以加载指定字体,让没装这个字体的电脑自动载入指定字体,很麻烦,要把字体转为特殊格式,而且对中文网页来说没啥实际意义,中文字体太大了,动不动10M一个