使用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实现精美横向滚动菜单按钮
Apr 14 HTML / CSS
CSS3 制作旋转的大风车(充满童年回忆)
Jan 30 HTML / CSS
纯CSS3打造动感漂亮时尚的扇形菜单
Mar 18 HTML / CSS
使用CSS3和Checkbox实现JQuery的一些效果
Aug 03 HTML / CSS
深入理解css属性的选择对动画性能的影响
Apr 20 HTML / CSS
CSS3中的@keyframes关键帧动画的选择器绑定
Jun 13 HTML / CSS
html5中localStorage本地存储的简单使用
Jun 16 HTML / CSS
详解使用postMessage解决iframe跨域通信问题
Nov 01 HTML / CSS
canvas实现滑动验证的实现示例
Aug 11 HTML / CSS
萌新HTML5 入门指南(二)
Nov 09 HTML / CSS
详解CSS伪元素的妙用单标签之美
May 25 HTML / CSS
深入理解CSS 中 transform matrix矩阵变换问题
Aug 30 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
全国FM电台频率大全 - 6 辽宁省
2020/03/11 无线电
使用Smarty 获取当前日期时间和格式化日期时间的方法详解
2013/06/18 PHP
php绘图之加载外部图片的方法
2015/01/24 PHP
php ci 获取表单中多个同名input元素值的代码
2016/03/25 PHP
PHP编程实现微信企业向用户付款的方法示例
2017/07/26 PHP
php判断电子邮件是否正确方法
2018/12/04 PHP
PHP使用Redis实现Session共享的实现示例
2019/05/12 PHP
B/S开发中常用javaScript技术与代码
2007/03/09 Javascript
javascript动态加载二
2012/08/22 Javascript
开启BootStrap学习之旅
2016/05/04 Javascript
jQuery实现的自动加载页面功能示例
2016/09/04 Javascript
javascript中replace使用方法总结
2017/03/01 Javascript
JS中定位 position 的使用实例代码
2017/08/06 Javascript
JavaScript输入分钟、秒倒计时技巧总结(附代码)
2017/08/17 Javascript
jQuery仿移动端支付宝键盘的实现代码
2018/08/15 jQuery
使用react render props实现倒计时的示例代码
2018/12/06 Javascript
d3绘制基本的柱形图的实现代码
2018/12/12 Javascript
微信小程序时间戳转日期的详解
2019/04/30 Javascript
vue实现简单的日历效果
2020/09/24 Javascript
vue实现权限控制路由(vue-router 动态添加路由)
2019/11/04 Javascript
JavaScript实现简单的计算器
2020/01/16 Javascript
JavaScript canvas实现跟随鼠标移动小球
2021/02/09 Javascript
Python 文件读写操作实例详解
2014/03/12 Python
python定向爬取淘宝商品价格
2018/02/27 Python
Pycharm更换python解释器的方法
2018/10/29 Python
对python cv2批量灰度图片并保存的实例讲解
2018/11/09 Python
python用quad、dblquad实现一维二维积分的实例详解
2019/11/20 Python
python程序输出无内容的解决方式
2020/04/09 Python
Python 如何查找特定类型文件
2020/08/17 Python
HTML5之SVG 2D入门8—文档结构及相关元素总结
2013/01/30 HTML / CSS
KELLER SPORTS荷兰:在线订购最好的运动产品
2020/10/13 全球购物
开展党的群众路线教育实践活动总结报告
2014/10/31 职场文书
法制工作总结2015
2015/07/23 职场文书
宣传委员竞选稿
2015/11/19 职场文书
PyCharm配置KBEngine快速处理代码提示冲突、配置命令问题
2021/04/03 Python
Node实现搜索框进行模糊查询
2021/06/28 Javascript