前端援用字体@font-face的多少优化要领

1 前 言

1.1 场 景

我们在页面展现时,为了更好的结果,平常运用了自定义的字体 @fant-face

之前在开辟的时刻运用了一些自定义字体,这里总结下本身寻觅的的一些处置惩罚要领。

本文只列出了引入当地字体,收集的字体因为实践不多,这里引见就少一些。

😂 献丑了 😂

2 正 文

2.1 当地字体

2.1.1 版 权

起首肯定要注意这个题目

2.1.2 字体定义

平常状况定义以下:

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

在某个我们要运用的该字体的classA上定义:

.classA {
    font-family:"Regular";
}

2.1.3 字体紧缩

平常的中文字体都要8-10M,相对于全部工程来讲太庞大,这里供应本身实践过的2种紧缩要领。

两种都须要列举出你运用过的字。

1 font-spider

官网:
http://font-spider.org/

支撑 gulp 构建插件

我在运用时,刚开始一向没紧缩胜利

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

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

2 Fontmin

官网:
http://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:https://www.webfont.com/

找到的一个体式格局,没有现实用过,不知道结果咋样,有兴致的能够尝尝。

3 后 记

感谢支撑。若不足之处,迎接人人指出,共勉。

假如以为不错,记得 点赞,感谢人人 😂

迎接关注 我的:
【Github】
【掘 金】
【简 书】

本文章采纳 学问同享签名-非商业性运用-雷同体式格局同享 4.0 国际允许协定 举行允许。

出处为:https://github.com/xrkffgg/Tools

    原文作者:xrkffgg
    原文地址: https://segmentfault.com/a/1190000019262268
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞