使用CSS3的font-face字体嵌入样式的方法讲解


Posted in HTML / CSS onMay 13, 2016

对于一个出色的网页,字体的选择是相对关键的,无奈设计师必须考虑用户的本地端是否有相应的字体,因此设计常常只能使用一些较为大众化的常见字体,而舍弃更加适合的字体。在 CSS3 中,这一情况将可以改变。CSS3 中引入了 font-face(嵌入字体类型),实验 font-face 可以把需要的字体上传到自己的服务器,再在服务器的网页中使用该字体并显示出来,无论浏览网页的用户的本地端是否有该字体。

语法:

CSS Code复制内容到剪贴板
  1. @font-face { font-family : name ; src : url ( url ) ; sRules }   

取值:
name  :? 字体名称。任何可能的 font-family 属性的值
url ( url )  :? 使用绝对或相对 url 地址指定OpenType字体文件
sRules  :? 样式表定义

说明:
设置嵌入HTML文档的字体。此规则无默认值。
此规则使你能够在网页上使用客户端本地系统上可能没有的字体。 url 地址必须指向 OpenType 字体文件(.eot或.ote)。此文件包含可以转换为 TrueType 字体的压缩字体数据,可以用来提供HTML文档使用该字体,或取代客户端系统已有的同名字体。

示例:
例如下面的效果:
使用CSS3的font-face字体嵌入样式的方法讲解

CSS Code复制内容到剪贴板
  1. @font-face {   
  2.     font-family'vanessalovesyoumedium';   
  3.     srcurl('vanessalovesyou-webfont.eot');   
  4.     srcurl('vanessalovesyou-webfont.eot?#iefix'format('embedded-opentype'),   
  5.          url('vanessalovesyou-webfont.ttf'format('truetype'),   
  6.     font-weightnormal;   
  7.     font-stylenormal;   
  8. }   
  9. #test-font {   
  10.     font-size24px;   
  11. }   
  12. #test-font span{   
  13.     font-family: vanessalovesyoumedium;   
  14. }  

使用 @font-face 定义字体所需要的文件,为了兼容各个浏览器,需要使用多种不同的字体格式,建议至少要有 .eot 和 .ttf 两种格式,.eot 用于 IE5+ ,.ttf 用于 Chrome 等现代浏览器,另外 .otf 也是不错的选择,也可以用于现代浏览器。

需要注意以下几点:
1.IE8及更早浏览器只支持微软自有的 .eot 格式
2.IE9.0-10.0部分支持 ttf 和 otf 字体格式
3.现代浏览器大多支持 .ttf 和 .otf 两种格式
4.现代浏览器需要从外部引用 @face-font 才能有效,IE 则可以直接在页面中使用 @face-font

HTML / CSS 相关文章推荐
CSS3属性使网站设计增强同时不消弱可用性
Aug 29 HTML / CSS
利用CSS3的transition属性实现滑动效果
Aug 05 HTML / CSS
轻松掌握CSS3中的字体大小单位rem的使用方法
May 24 HTML / CSS
10分钟理解CSS3 FlexBox弹性布局
Dec 20 HTML / CSS
CSS3 实现的缩略图悬停效果
Dec 09 HTML / CSS
详解HTML5中垂直上下居中的解决方案
Dec 20 HTML / CSS
html5 localStorage本地存储_动力节点Java学院整理
Jul 06 HTML / CSS
HTML5 微格式和相关的属性名称
Feb 10 HTML / CSS
html5 canvas fillRect坐标和大小的问题解决方法
Mar 26 HTML / CSS
HTML5+CSS3模仿优酷视频截图功能示例
Jan 05 HTML / CSS
浅谈Html5移动端ios/Android兼容性总结
Jun 01 HTML / CSS
css3带你实现3D转换效果
Feb 24 HTML / CSS
几个CSS3的flex弹性盒模型布局的简单例子演示
May 12 #HTML / CSS
CSS3中的transform属性进行2D和3D变换的基本用法
May 12 #HTML / CSS
CSS3制作气泡对话框的实例教程
May 10 #HTML / CSS
详解CSS3的box-shadow属性制作边框阴影效果的方法
May 10 #HTML / CSS
解决CSS3的opacity属性带来的层叠顺序问题
May 09 #HTML / CSS
详解CSS3的opacity属性设置透明效果的用法
May 09 #HTML / CSS
CSS3中使用RGBa来调节透明度的教程
May 09 #HTML / CSS
You might like
【COS正片】蕾姆睡衣cos,纯洁可爱被治愈了 cn名濑弥七
2020/03/02 日漫
php 调用百度sms来发送短信的实现示例
2018/11/02 PHP
jscript之Read an Excel Spreadsheet
2007/06/13 Javascript
javascript简单事件处理和with用法介绍
2013/09/16 Javascript
使用JavaScript实现网页版Pongo设计思路及源代码分享
2014/06/16 Javascript
类似于QQ的右滑删除效果的实现方法
2016/10/16 Javascript
JavaScript自定义分页样式
2017/01/17 Javascript
详解vue移动端日期选择组件
2018/02/22 Javascript
vue + webpack如何绕过QQ音乐接口对host的验证详解
2018/07/01 Javascript
解决Layui数据表格中checkbox位置不居中的方法
2018/08/15 Javascript
Vue前后端不同端口的实现方法
2018/09/19 Javascript
Vue.js递归组件实现组织架构树和选人功能
2019/07/04 Javascript
手把手15分钟搭一个企业级脚手架
2019/09/16 Javascript
react 原生实现头像滚动播放的示例
2020/04/21 Javascript
Vue Cli3 打包配置并自动忽略console.log语句的方法
2020/04/23 Javascript
js实现浏览器打印功能的示例代码
2020/07/15 Javascript
使用python分析git log日志示例
2014/02/27 Python
Python利用正则表达式匹配并截取指定子串及去重的方法
2015/07/30 Python
python对html过滤处理的方法
2018/10/21 Python
通过Turtle库在Python中绘制一个鼠年福鼠
2020/02/03 Python
利用python中集合的唯一性实现去重
2020/02/11 Python
python 实现 hive中类似 lateral view explode的功能示例
2020/05/18 Python
Python通过文本和图片生成词云图
2020/05/21 Python
Python selenium爬取微信公众号文章代码详解
2020/08/12 Python
python解包用法详解
2021/02/17 Python
免税水晶:Duty Free Crystal
2019/05/13 全球购物
英国领先的餐饮折扣俱乐部:Gourmet Society
2020/07/26 全球购物
同步和异步有何异同,在什么情况下分别使用他们?
2012/12/28 面试题
英语专业应届生求职信范文
2013/11/15 职场文书
个人先进事迹总结
2015/02/26 职场文书
三好学生竞选稿
2015/11/21 职场文书
详细聊聊浏览器是如何看闭包的
2021/11/11 Javascript
SpringBoot中HttpSessionListener的简单使用方式
2022/03/17 Java/Android
2021年国产动漫公司排行前十名,玄机科技上榜,第二推出过铠甲勇士
2022/03/18 杂记
使用Python开发贪吃蛇游戏 SnakeGame
2022/04/30 Python
阿里面试Nacos配置中心交互模型是push还是pull原理解析
2022/07/23 Java/Android