博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
前端引用字体@font-face的若干优化方法
阅读量:7245 次
发布时间:2019-06-29

本文共 1395 字,大约阅读时间需要 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

官网:

支持 gulp 构建插件

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

之后发现是由于自己下载的字体版本有点低

这里列出一个找到的字体下载网址,觉得不错:

2 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:

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

3 后 记

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

如果觉得不错,记得 点赞,谢谢大家 ?

欢迎关注 我的:

本文章采用进行许可。

出处为:

转载地址:http://idbbm.baihongyu.com/

你可能感兴趣的文章
selenium-webdriver(python) (十六) --unittest 框架
查看>>
高可用Hadoop平台-答疑篇
查看>>
跟我一起数据挖掘(9)——R语言
查看>>
Silverlight实用窍门系列:49.Silverlight中管理独立存储--Isolated Storage【附带实例源码】...
查看>>
[perl]数据相关
查看>>
Oracle数据库锁表及解锁进程
查看>>
CSS魔法堂:Absolute Positioning就这个样
查看>>
PostgreSQL standby in 64bit to 32bit or reverse enviroment
查看>>
PostgreSQL 如何潇洒的处理每天上百TB的数据增量
查看>>
架构师画像
查看>>
一分钟了解阿里云产品:消息队列
查看>>
(二十三)变量名的命名
查看>>
如何保证摘除公网EIP的容器服务VPC集群可以正常访问公网
查看>>
linux进程状态浅析
查看>>
【JavaScript】DOM节点常用方法介绍02
查看>>
非官方统计2018微信年度账单实现
查看>>
微信小程序练手 demo 之天气小程序总结(流水账)
查看>>
异步操作系列之Generator函数与Async函数
查看>>
水平无限循环弹幕的实现
查看>>
老前端出坑小程序(一)
查看>>