答案是使用@font-face规则引入自定义字体,需关注格式兼容性、性能优化与版权问题。通过定义font-family和src指定字体文件,优先提供WOFF2与WOFF格式以兼顾性能与兼容;利用font-display: swap避免文本不可见,结合子集化、预加载和CDN提升加载速度;注意浏览器对EOT、TTF等旧格式的支持顺序;严格遵守字体许可协议,规避商业使用风险。

在CSS中引入自定义字体,核心机制在于
@font-face
要将自定义字体引入你的网页,你需要用到CSS的
@font-face
最基本的结构是这样的:
@font-face {
font-family: 'MyCustomFont'; /* 给你的字体起个名字,之后在CSS里就用这个名字 */
src: url('fonts/mycustomfont.woff2') format('woff2'), /* 现代浏览器首选 */
url('fonts/mycustomfont.woff') format('woff'); /* 广泛支持 */
font-weight: normal; /* 字体的粗细,可以根据你的字体文件来设置 */
font-style: normal; /* 字体的样式,比如斜体 */
font-display: swap; /* 推荐加上,优化字体加载用户体验 */
}
body {
font-family: 'MyCustomFont', sans-serif; /* 在需要的地方应用你的自定义字体 */
}这里面有几个关键点:
立即学习“前端免费学习笔记(深入)”;
font-family
body
font-family: 'MyCustomFont', sans-serif;
src
url()
url()
format()
format('woff2')关于字体格式,这是个老生常谈但又不得不提的话题。现在主流且推荐的顺序是:
我的建议是,至少提供WOFF2和WOFF两种格式,这样能兼顾性能和兼容性。如果考虑到一些老旧的浏览器,TTF也可以作为备选加入。
src
字体文件,尤其是那些包含了多种字重、字形的字体家族,体积往往不小。这在网络环境不佳时,很容易成为网页加载的瓶颈,导致用户看到页面时,要么是默认字体跳变(FOUC - Flash of Unstyled Content),要么是文字干脆不显示(FOIT - Flash of Invisible Text)。我以前也遇到过,页面内容都出来了,但文字却迟迟不出现,用户体验极差。
要解决这个问题,我们可以从几个方面入手:
font-display
swap
fallback
optional
fallback
block
你可以在
@font-face
font-display: swap;
字体子集化 (Subsetting): 如果你的网站只用到了字体中的一部分字符(比如只用到英文字母和数字,或者只用到某个特定的汉字集合),那么没必要加载整个字体文件。你可以使用一些工具(例如Font Squirrel的
@font-face
fontTools
预加载 (Preload): 使用
<link rel="preload" as="font" crossorigin="anonymous" href="fonts/mycustomfont.woff2">
crossorigin
CDN加速: 将字体文件部署到CDN(内容分发网络)上。CDN能够将字体文件分发到离用户最近的服务器,从而加快下载速度。很多字体服务商,比如Google Fonts,本身就是基于CDN提供服务的。
异步加载: 对于一些非核心的字体,可以考虑在页面加载完成后再通过JavaScript动态加载,避免阻塞首屏渲染。但这会增加实现的复杂性,通常配合
font-display: swap
浏览器兼容性,这真是前端开发永远的痛,字体也不例外。虽然现在WOFF2和WOFF已经覆盖了绝大部分现代浏览器,但如果你需要支持一些老旧的IE浏览器,或者一些特殊的移动端浏览器,你可能就会发现,同样的代码在不同浏览器下表现不一样。我记得有一次,一个项目要求兼容到IE9,结果自定义字体在IE里就是出不来,最后排查发现是EOT格式没加,或者
src
解决这种兼容性问题,核心在于
@font-face
src
一个比较稳妥的
src
@font-face {
font-family: 'YourFontName';
src: url('yourfont.woff2') format('woff2'), /* 现代浏览器,压缩率高 */
url('yourfont.woff') format('woff'), /* 广泛支持 */
url('yourfont.ttf') format('truetype'); /* 旧版Android/iOS,以及一些桌面浏览器 */
/* url('yourfont.eot?#iefix') format('embedded-opentype'); /* 如果需要支持IE6-IE8,但现在基本不用了 */
font-weight: normal;
font-style: normal;
font-display: swap;
}这里有个小细节,针对IE的EOT格式,通常会在URL后面加上
?#iefix
此外,
format()
所以,我的经验是,不要吝啬多提供几种格式。用工具生成
@font-face
src
字体版权,这真的是一个很容易被忽视,但一旦出问题就可能非常麻烦的领域。很多开发者在选择字体时,可能只关注字体的美观性、性能,却很少去仔细阅读字体的许可协议。我见过不少公司,因为使用了未经授权的字体,最终不得不支付高昂的版权费,甚至面临法律诉讼。这可不是开玩笑的,字体文件和图片、音乐一样,都是受版权保护的数字资产。
当你决定在项目中使用自定义字体时,第一步,也是最重要的一步,就是仔细核查字体的许可协议。这决定了你是否可以免费使用、是否可以用于商业项目、是否可以修改,以及是否需要署名等。
市面上常见的字体许可类型大致有几种:
以上就是CSS字体如何引入_CSS引入自定义字体方法教程的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号