使用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系列之3D制作方法案例
Aug 14 HTML / CSS
彻底弄明白CSS3的Media Queries(跨平台设计)
Jul 27 HTML / CSS
用纯css3和html制作泡沫对话框实现代码
Mar 21 HTML / CSS
CSS3新增布局之: flex详解
Jun 18 HTML / CSS
CSS实现进度条和订单进度条的示例
Nov 05 HTML / CSS
详解HTML5表单新增属性
Dec 21 HTML / CSS
HTML5-WebSocket实现聊天室示例
Dec 15 HTML / CSS
Html5之svg可缩放矢量图形_动力节点Java学院整理
Jul 17 HTML / CSS
html5的新增的标签和废除的标签简要概述
Feb 20 HTML / CSS
HTML5 创建canvas元素示例代码
Jun 04 HTML / CSS
详解前端HTML5几种存储方式的总结
Dec 27 HTML / CSS
H5调用相机拍照并压缩图片的实例代码
Jul 20 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
上海牌131型七灯四波段四喇叭一级收音机
2021/03/02 无线电
php判断文件上传类型及过滤不安全数据的方法
2014/12/17 PHP
php控制文件下载速度的方法
2015/03/24 PHP
PHP实现获取中英文首字母
2015/06/19 PHP
优化WordPress中文章与评论的时间显示
2016/01/12 PHP
一个刚完成的layout(拖动流畅,不受iframe影响)
2007/08/17 Javascript
JAVASCRIPT keycode总结
2009/02/04 Javascript
能说明你的Javascript技术很烂的五个原因分析
2011/10/28 Javascript
高性能Javascript笔记 数据的存储与访问性能优化
2012/08/02 Javascript
JS防止用户多次提交的简单代码
2013/08/01 Javascript
jQuery实现瀑布流的取巧做法分享
2015/01/12 Javascript
JavaScript常用字符串与数组扩展函数小结
2016/04/24 Javascript
JS使用cookie实现只出现一次的广告代码效果
2017/04/22 Javascript
Vue.js如何实现路由懒加载浅析
2017/08/14 Javascript
微信小程序如何获取openid及用户信息
2018/01/26 Javascript
JS引用传递与值传递的区别与用法分析
2018/06/01 Javascript
Bootstrap Fileinput 4.4.7文件上传实例详解
2018/07/25 Javascript
JS使用iView的Dropdown实现一个右键菜单
2019/05/06 Javascript
Async/Await替代Promise的6个理由
2019/06/15 Javascript
vant时间控件使用方法详解
2020/12/24 Javascript
[02:54]辉夜杯主赛事第二日败者组 iG.V赛后采访
2015/12/26 DOTA
python基础教程之分支、循环简单用法
2016/06/16 Python
Python matplotlib绘图可视化知识点整理(小结)
2018/03/16 Python
Python字符串的一些操作方法总结
2019/06/10 Python
Python3 venv搭建轻量级虚拟环境的步骤(图文)
2019/08/09 Python
python 字段拆分详解
2019/12/17 Python
使用bandit对目标python代码进行安全函数扫描的案例分析
2021/01/27 Python
css3中单位px,em,rem,vh,vw,vmin,vmax的区别及浏览器支持情况
2016/12/06 HTML / CSS
什么是接口(Interface)?
2013/02/01 面试题
优秀员工个人的自我评价
2013/11/29 职场文书
2015年元旦主持词开场白
2014/12/14 职场文书
迟到检讨书
2015/01/26 职场文书
汽车转让协议书
2015/01/29 职场文书
用基于python的appium爬取b站直播消费记录
2021/04/17 Python
Python代码风格与编程习惯重要吗?
2021/06/03 Python
MyBatis在注解上使用动态SQL方式(@select使用if)
2022/07/07 Java/Android