在CSS中通过@font-face属性来实现网页中嵌入特殊字体。
首先获取要使用字体的三种文件格式.EOT、.TTF或.OTF、.SVG,确保能在主流浏览器中都能正常显示该字体。
.EOT,适用于Internet Explorer 4.0+
.TTF或.OTF,适用于Firefox 3.5、Safari、Opera
.SVG,适用于Chrome、IPhone
最常见的是.TTF文件,需要通过这种文件格式转换为其余两种文件格式。
在css中进行如下声明:
@font-face {
font-family: 'fontNameRegular'
src: url('fontName.eot')
src: local('fontName Regular'),
local('fontName'),
url('fontName.woff') format('woff'),
url('fontName.ttf') format('truetype'),
url('fontName.svg#fontName') format('svg')
}
/*其中fontName替换为你的字体名称*/
在css中使用这个字体
h1{font-family: fontNameRegular}
尝试着用办双引号去掉或者把
字体设置成font-family:'Microsoft YaHei'页面出现的问题就解决了,font-family:'雅黑'此种写法IE6.0不兼容。
1、font-family属性可以为标签设置字体,浏览器会从左至右依次查找是否有该字体,并将找到的第一个字体用于显示。如果没找到,则使用默认字体(Windows XP简体中文版一般是宋体)。
2、但还有个未定义行为,若找到的第一个是英文字体,而要显示汉字时,应该如何处理。Chrome和Firefox是继续往后查,直到找到能正确显示的字体;而IE(我只测试了IE6)则直接改用默认字体显示汉字了。
3、目前我只能用CSS hack的方法来判断(即只有IE能识别*开头的属性),但也只是提前了中文字体,英文字体就无效了:
body { font-family:Verdana,微软雅黑*font-family:微软雅黑,Verdana}
4、此外,有时候找到的字体无法显示特殊符号,IE就用方框来显示了,非常无语。
例如音乐符号:&#9834
如果你装了微软雅黑字体,那么在IE下看到的会是个方框,但Chrome和Firefox下正常。
5、font:在一个声明中设置所有字体属性;
font有以下几个属性:
font-style:字体样式
font-variant:字体异体
font-weight:字体粗细
font-size/line-height:字体大小/行高
font-family:字体系列(比如宋体、黑体等)
6、设定字体为微软雅黑 Bold字体"就可以写为:font-family:"微软雅黑"font-weight:bold
CSS中可以使用font-face属性即可实现调用任何外部等特殊字体。
font-face属性介绍及其实例:
对浏览器的支持:
Firefox、Chrome、Safari 以及 Opera 支持 .ttf (True Type Fonts) 和 .otf (OpenType Fonts) 类型的字体。
Internet Explorer 9+ 支持新的 font-face 规则,但是仅支持 .eot 类型的字体 (Embedded OpenType)。
使用您需要的字体。
在新的 font-face 规则中,您必须首先定义字体的名称(比如 myFirstFont),然后指向该字体文件。
如需为 HTML 元素使用字体,请通过 font-family 属性来引用字体的名称 (myFirstFont):
使用粗体字体。
您必须为粗体文本添加另一个包含描述符的 @font-face。
文件 "aa.ttf" 是另一个字体文件,它包含了 Sansation 字体的粗体字符。
只要 font-family 为 "myFirstFont" 的文本需要显示为粗体,浏览器就会使用该字体。
通过这种方式,我们可以为相同的字体设置许多 @font-face 规则。
实际案例:
案例1: <style>@font-face
{
font-family: myFirstFont
src: url('aa.ttf'),
url('aa.eot') /* IE9+,可以是具体的实际链接 */
}
div
{
font-family:myFirstFont
}
</style> 案例2: @font-face
{
font-family: myFirstFont
src: url('aa.ttf'),
url('aa.eot') /* IE9+ */
font-weight:bold
}
注意事项:
A、Internet Explorer 8 以及更早的版本不支持新的 font-face 规则。
B、代码中注意负符号,均为英文状态下。
C、字体文件格式必须添加后缀,且链接中必须带后缀。