前端引用字体@font-face的若干优化方法

1 前 言

1.1 场 景

咱们在页面展现时,为了更好的效果,通常使用了自定义的字体 @fant-facecss

以前在开发的时候使用了一些自定义字体,这里总结下本身寻找的的一些处理办法。git

本文只列出了引入本地字体,网络的字体因为实践很少,这里介绍就少一些。github

😂 献丑了 😂web

2 正 文

2.1 本地字体

2.1.1 版 权

首先必定要注意这个问题 npm

2.1.2 字体定义

通常状况定义以下:gulp

@font-face {
    font-family:"Regular";
    src:url('../font/Regular.otf');
}
复制代码

在某个咱们要使用的该字体的classA上定义:浏览器

.classA {
    font-family:"Regular";
}
复制代码

2.1.3 字体压缩

通常的中文字体都要8-10M,相对于整个工程来讲太巨大,这里提供本身实践过的2种压缩方法。bash

两种都须要列举出你使用过的字。网络

1 font-spider

官网:font-spider.org/ide

支持 gulp 构建插件

我在使用时,刚开始一直没压缩成功

以后发现是因为本身下载的字体版本有点低

这里列出一个找到的字体下载网址,以为不错:www.fontke.com/font/

2 Fontmin

官网:ecomfe.github.io/fontmin/

这个比较方便的是有一个客户端能够操做

2.1.4 字体加载

虽然有压缩的功能,但必须提供出全部使用过的字体,并且我想的是个人项目中就默认一个好看的字体。

这样就遇到一个问题,在第一次加载的时候,浏览器就会用一些时间来加载这个字体文件。

而在加载完成以前,页面就会空白,也就是FOIT(Flash of Invisible Text)

1 FOUT

FOUT(Flash of Unstyled Text)大意就是在字体加载完成前,浏览器会显示font-family的顺序字体

当加载完成后,才会替换成定义的字体,设置以下:

@font-face {
    ...
    font-display: swap;
    ...
}
复制代码

这样的效果,就是会在页面中看到的一个字体替换的效果😂

2 FontFaceObserver

而后我想的是,有没有什么办法能够判断字体加载完成了呢?

安装:

npm i fontfaceobserver

页面中:

// css 中 @font-face 已定义好
import FontFaceObserver from 'fontfaceobserver'

loadfont(){
    console.time("字体加载用时")
    var ooo = new FontFaceObserver('Regular')
    ooo.load().then(() =>{
        document.getElementById('index').style.fontFamily = 'Regular'
        console.timeEnd("字体加载用时")
    })
},
复制代码

同时能够加上一个loading的动画,这样效果就比较好了😎

2.2 网络字体

2.2.1 引入

webfont:www.webfont.com/

找到的一个方式,没有实际用过,不知道效果咋样,有兴趣的能够试试。

3 后 记

感谢支持。若不足之处,欢迎你们指出,共勉。

若是以为不错,记得 点赞,谢谢你们 😂

欢迎关注 个人: 【Github】 【掘 金】 【简 书】

知识共享许可协议
本文章采用知识共享署名-非商业性使用-相同方式共享 4.0 国际许可协议进行许可。

出处为:github.com/xrkffgg/Too…

相关文章
相关标签/搜索