在之前我们有设置过页面使用的字体: font-family
- 我们需要提供
一个或多个字体种类名称,浏览器会在列表中搜寻,直到找到它所运行的系统上可用的字体; - 这样的方式完全没有问题,但是对于传统的web开发人员来说,
字体选择是有限的; - 这就是所谓的
Web-safe 字体; - 并且这种默认可选的字体
并不能进行一些定制化的需求;
比如下面的字体样式, 系统的字体肯定是不能实现的

Web fonts的工作原理
首先, 我们需要通过一些渠道获取到希望使用的字体
- 对于
某些收费的字体, 我们需要获取到对应的授权; - 对于某些
公司定制的字体, 需要设计人员来设计; - 对于某些
免费的字体, 我们需要获取到对应的字体文件;
其次, 在我们的CSS代码当中使用该字体(重要)
最后, 在部署静态资源时, 将HTML/CSS/JavaScript/Font一起部署在静态服务器中
用户的角度
- 浏览器一个网页时, 因为代码中有引入字体文件,
字体文件会被一起下载下来; - 浏览器会根据使用的字体在
下载的字体文件中查找、解析、使用对应的字体; 在浏览器中使用对应的字体显示内容;
使用Web Fonts
- 在字体天下网站下载一个字体,(默认下载下来的是ttf文件)。
- 将
字体放到对应的目录中。 - 通过
@font-face来引入字体, 并且设置格式。

- 使用字体。

注意: @font-face 用于加载一个自定义的字体;
web-fonts的兼容性
*我们刚才使用的字体文件是 .ttf, 它是TrueType字体
- 在开发中某些浏览器可能不支持该字体, 所以为了浏览器的兼容性问题, 我们需要有对应其他格式的字体。
TrueType字体:拓展名是 .ttf
OpenType/TrueType字体:拓展名是 .ttf、.otf,建立在TrueType字体之上Embedded OpenType字体:拓展名是 .eot,OpenType字体的压缩版SVG字体:拓展名是 .svg、 .svgzWOFF表示Web Open Font Format web开放字体:拓展名是 .woff,建立在TrueType字体之上
这里我们提供一个网站来生产对应的字体文件:https://font.qqe2.com/# 暂时可用
web fonts兼容性写法
如果我们具备很强的兼容性, 那么可以如下格式编写

这被称为"bulletproof @font-face syntax(刀枪不入的@font-face语法)":
- 这是
Paul Irish早期的一篇文章提及后@font-face开始流行起来 (Bulletproof @font-face Syntax)
src用于指定字体资源
url:指定资源的路径format:用于帮助浏览器快速识别字体的格式
本文介绍了如何使用WebFonts技术在网页中引入自定义字体,包括从字体资源获取到CSS代码的编写,以及在部署时考虑的浏览器兼容性问题。通过@font-face规则加载字体文件,并提供了不同格式的字体以确保跨浏览器支持。同时,文章提到了一个在线工具用于生成兼容性更好的字体文件。
1061

被折叠的 条评论
为什么被折叠?



