css3个性化字体_动力节点Java学院整理


Posted in HTML / CSS onJuly 12, 2017

在网页中,我们可以用CSS的font-family属性来定义字体,然而定义的字体在用户的电脑上能否正确呈现则要看用户的电脑是否安装了该字体。我们经常能看到国外的一些个人网站使用了非常漂亮的字体,而这些字体通常在用户的电脑中是没有安装的,所以用font-family属性就无法实现了,今天我们就介绍使用@font-face实现个性化字体。

CSS3 @font-face

说@font-face是CSS3的新特性并不准确,因为CSS2就已经支持了这一特性,并且Internet Explorer早在第5版的时候就已经支持它了,不过IE实现方式是通过自有的eot(Embeded Open Type)字体格式,其它浏览器都不支持这个格式。@font-face支持如下属性:

font-family:设置文本的字体名称。

font-style:设置文本样式。

font-variant:设置文本是否大小写。

font-weight:设置文本的粗细。

font-stretch:设置文本是否横向的拉伸变形。

font-size:设置文本字体大小。

src:设置自定义字体的相对路径或者绝对路径。

@font-face浏览器兼容性如下:
 

css3个性化字体_动力节点Java学院整理

一个简单例子

先声明一个名为ChantelliAntiquaRegular的字体,有一种老的写法是这样的:

@font-face {
    font-family: "ChantelliAntiquaRegular";
    src: url("Chantelli_Antiqua-webfont.eot");
    src: local("☺"), url("Chantelli_Antiqua-webfont.woff") format("woff"), url("Chantelli_Antiqua-webfont.ttf") format("truetype"), url("Chantelli_Antiqua-webfont.svg#webfontZjhIjbDc") format("svg");
    font-weight: normal;
    font-style: normal;
}

第一个src是兼容IE,第二个src是兼容其它浏览器。local("☺")是一种hack写法,避免从客户端加载字体,这种写法在Android系统中有BUG,改进方案是声明两个@font-face,如下:

@font-face {
    font-family: "ChantelliAntiquaRegular";
    src: url("Chantelli_Antiqua-webfont.eot");
}
 
@font-face {
    font-family: "ChantelliAntiquaRegular";
    src: url(//:) format("no404"), url("Chantelli_Antiqua-webfont.woff") format("woff"), url("Chantelli_Antiqua-webfont.ttf") format("truetype"), url("Chantelli_Antiqua-webfont.svg#webfontMFqI76bT") format("svg");
    font-weight: normal;
    font-style: normal;
}

我们首先声明一个引用eot字体文件的@font-face,以确保它在IE中能正常工作,第二个@font-face引用了多个字体格式是为了兼容其它浏览器,它们将按顺序查找,直到找到支持的格式,这意味着同一个字体需要有多个格式。url(//:) format("no404")是一种Bulletproof写法。

其它的HTML和CSS代码如下:
 

.font-face-display {
    font: 66px ChantelliAntiquaRegular, Helvetica, sans-serif;
}
 
<div class="font-face-display">Take me to your heart</div>

最重效果如下:

css3个性化字体_动力节点Java学院整理

免费字体网站Font Squirrel

Font Squirrel是一个非常优秀的免费字体资源网站,收集了很多高品质字体供网页设计者免费下载,还有个字体格式生成工具@font-face generator,上传一个字体文件,可以生成多种字体格式及CSS代码,非常有用。如果你需要一些优秀的免费英文字体,这是个好去处。

css3个性化字体_动力节点Java学院整理

想要丰富多彩的页面就需要有更多的字体样式,人们想出了很多字体替代方案,除了@font-face方案外还有sIFR、Cufon、Typeface.js等,还有.webfont,简单说,.webfont 就是在字体中嵌入了访问许可表,浏览器可以读出这些许可信息,并决定是否应该下载和渲染这些字体。另外还有Typekit也是一种值得关注的方案,将字体放在第三方服务器上供调用。这些方案的优缺点,将会在以后做详细的介绍。

HTML / CSS 相关文章推荐
CSS3中border-radius属性设定圆角的使用技巧
May 10 HTML / CSS
让IE可以变相支持CSS3选择器
Jan 21 HTML / CSS
基于css3实现漂亮便签样式
Mar 18 HTML / CSS
CSS3中的display:grid,网格布局介绍
Oct 30 HTML / CSS
5分钟弄清楚html5的drag and drop(小结)
Apr 10 HTML / CSS
HTML5 canvas 基本语法
Aug 26 HTML / CSS
让IE下支持Html5的placeholder属性的插件
Sep 02 HTML / CSS
快速实现一个简单的canvas迷宫游戏的示例
Jul 04 HTML / CSS
移动端Html5中百度地图的点击事件
Jan 31 HTML / CSS
HTML5自定义属性的问题分析
Aug 16 HTML / CSS
CSS实现切角+边框+投影+内容背景色渐变效果
Nov 01 HTML / CSS
CSS3弹性布局内容对齐(justify-content)属性使用详解
Jul 31 #HTML / CSS
网页布局中CSS样式无效的十个重要原因详解
Aug 10 #HTML / CSS
css3实现一个div设置多张背景图片及background-image属性实例演示
Aug 10 #HTML / CSS
Web前端绘制0.5像素的几种方法
Aug 11 #HTML / CSS
css3 box-shadow阴影(外阴影与外发光)图示讲解
Aug 11 #HTML / CSS
css3之UI元素状态伪类选择器实例演示
Aug 11 #HTML / CSS
CSS3系列之3D制作方法案例
Aug 14 #HTML / CSS
You might like
PHP 事件机制(2)
2011/03/23 PHP
双冒号 ::在PHP中的使用情况
2015/11/05 PHP
PHP使用preg_split()分割特殊字符(元字符等)的方法分析
2017/02/04 PHP
PHP处理bmp格式图片的方法分析
2017/07/04 PHP
PHP时间戳和日期相互转换操作实例小结
2018/12/18 PHP
使用focus方法让光标默认停留在INPUT框
2014/07/29 Javascript
javascript 兼容各个浏览器的事件
2015/02/04 Javascript
javascript笛卡尔积算法实现方法
2015/04/08 Javascript
javascript实现日期时间动态显示示例代码
2015/09/08 Javascript
一种新的javascript对象创建方式Object.create()
2015/12/28 Javascript
JS简单实现浮动窗口效果示例
2016/09/07 Javascript
运用js教你轻松制作html音乐播放器
2020/04/17 Javascript
javascript实现无法关闭的弹框
2016/11/27 Javascript
使用canvas及js简单生成验证码方法
2017/04/02 Javascript
为什么我们要做三份 Webpack 配置文件
2017/09/18 Javascript
本地搭建微信小程序服务器的实现方法
2017/10/27 Javascript
实例详解BootStrap的动态模态框及静态模态框
2018/08/13 Javascript
给localStorage设置一个过期时间的方法分享
2018/11/06 Javascript
js array数组对象操作方法汇总
2019/03/18 Javascript
Vue 3.0 全家桶抢先体验
2020/04/28 Javascript
python基础教程之python消息摘要算法使用示例
2014/02/10 Python
python3 实现的对象与json相互转换操作示例
2019/08/17 Python
如何分离django中的媒体、静态文件和网页
2019/11/12 Python
Django 实现 Websocket 广播、点对点发送消息的代码
2020/06/03 Python
CSS3+js实现简单的时钟特效
2015/03/18 HTML / CSS
后勤部经理岗位职责
2014/02/23 职场文书
应届毕业生自荐信例文
2014/02/26 职场文书
2014年小学辅导员工作总结
2014/12/23 职场文书
幼儿园教学工作总结2015
2015/05/12 职场文书
房屋维修申请报告
2015/05/18 职场文书
幼儿园家长反馈意见
2015/06/03 职场文书
python实现简单的名片管理系统
2021/04/26 Python
使用redis实现延迟通知功能(Redis过期键通知)
2021/09/04 Redis
用Python爬取英雄联盟的皮肤详细示例
2021/12/06 Python
SQLServer RANK() 排名函数的使用
2022/03/23 SQL Server
Vite + React从零开始搭建一个开源组件库
2022/06/25 Javascript