使用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 三维变形实现立体方块特效源码
Dec 15 HTML / CSS
利用CSS3的flexbox实现水平垂直居中与三列等高布局
Sep 12 HTML / CSS
CSS教程:CSS3圆角属性
Apr 02 HTML / CSS
浅析几个CSS3常用功能的写法
Jun 05 HTML / CSS
用CSS3实现瀑布流布局的示例代码
Nov 10 HTML / CSS
利用CSS3实现文字折纸效果实例代码
Jul 10 HTML / CSS
详解HTML5中垂直上下居中的解决方案
Dec 20 HTML / CSS
自定义html标记替换html5新增元素
Oct 17 HTML / CSS
有关HTML5 Video对象的ontimeupdate事件(Chrome上无效)的问题
Jul 19 HTML / CSS
html5+css如何实现中间大两头小的轮播效果
Dec 06 HTML / CSS
Canvas多边形绘制的实现方法
Aug 05 HTML / CSS
Html5 video标签视频的最佳实践
Feb 26 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
php格式化工具Beautify PHP小小BUG
2008/04/24 PHP
php 多个submit提交表单 处理方法
2009/07/07 PHP
php at(@)符号的用法简介
2009/07/11 PHP
Joomla数据库操作之JFactory::getDBO用法
2016/05/05 PHP
php自定义时间转换函数示例
2016/12/07 PHP
php中curl和soap方式请求服务超时问题的解决
2018/06/11 PHP
php实现多站点共用session实现单点登录的方法详解
2019/09/18 PHP
Jquery中getJSON在asp.net中的使用说明
2011/03/10 Javascript
jquery获取URL中参数解决中文乱码问题的两种方法
2013/12/18 Javascript
使用Jquery获取带特殊符号的ID 标签的方法
2014/04/30 Javascript
jQuery插件boxScroll实现图片轮播特效
2015/07/14 Javascript
javascript引用类型之时间Date和数组Array
2015/08/27 Javascript
canvas 弹幕效果(实例分享)
2017/01/11 Javascript
详解Vue2+Echarts实现多种图表数据可视化Dashboard(附源码)
2017/03/21 Javascript
简单谈谈vue的过渡动画(推荐)
2017/10/11 Javascript
Node中使用ES6语法的基础教程
2018/01/05 Javascript
webpack4.0打包优化策略整理小结
2018/03/30 Javascript
python命令行参数sys.argv使用示例
2014/01/28 Python
python在windows下实现备份程序实例
2014/07/04 Python
使用python生成杨辉三角形的示例代码
2018/08/29 Python
python实现支付宝转账接口
2019/05/07 Python
python3用PIL把图片转换为RGB图片的实例
2019/07/04 Python
PowerBI和Python关于数据分析的对比
2019/07/11 Python
python元组的概念知识点
2019/11/19 Python
python list数据等间隔抽取并新建list存储的例子
2019/11/27 Python
Python中类似于jquery的pyquery库用法分析
2019/12/02 Python
如何基于windows实现python定时爬虫
2020/05/01 Python
联想墨西哥官方网站:Lenovo墨西哥
2016/08/17 全球购物
linux面试题参考答案(10)
2016/10/26 面试题
销售员个人求职的自我评价
2014/02/10 职场文书
二年级班级文化建设方案
2014/05/10 职场文书
简单通用的简历自我评价
2014/09/21 职场文书
北京英文导游词
2015/02/12 职场文书
二年级数学教学反思
2016/02/16 职场文书
Nginx的反向代理实例详解
2021/03/31 Servers
Win11 Beta 预览版 22621.575 和 22622.575更新补丁KB5016694发布(附更新内容大全)
2022/08/14 数码科技