美文网首页前端技术
前端引用字体@font-face的若干优化方法

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

作者: xrkffgg | 来源:发表于2019-05-22 16:50 被阅读4次

    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

    相关文章

      网友评论

        本文标题:前端引用字体@font-face的若干优化方法

        本文链接:https://www.haomeiwen.com/subject/lzvuzqtx.html