咱們在頁面展現時,爲了更好的效果,通常使用了自定義的字體 @fant-face
。css
以前在開發的時候使用了一些自定義字體,這裏總結下本身尋找的的一些處理辦法。git
本文只列出了引入本地字體,網絡的字體因爲實踐很少,這裏介紹就少一些。github
😂 獻醜了 😂web
首先必定要注意這個問題 npm
通常狀況定義以下:gulp
@font-face {
font-family:"Regular";
src:url('../font/Regular.otf');
}
複製代碼
在某個咱們要使用的該字體的classA
上定義:瀏覽器
.classA {
font-family:"Regular";
}
複製代碼
通常的中文字體都要8-10M
,相對於整個工程來講太巨大,這裏提供本身實踐過的2種壓縮方法。bash
兩種都須要列舉出你使用過的字。網絡
官網:font-spider.org/ide
支持
gulp
構建插件
我在使用時,剛開始一直沒壓縮成功
以後發現是因爲本身下載的字體版本有點低
這裏列出一個找到的字體下載網址,以爲不錯:www.fontke.com/font/
這個比較方便的是有一個客戶端能夠操做
雖然有壓縮的功能,但必須提供出全部使用過的字體,並且我想的是個人項目中就默認一個好看的字體。
這樣就遇到一個問題,在第一次加載的時候,瀏覽器就會用一些時間來加載這個字體文件。
而在加載完成以前,頁面就會空白,也就是FOIT(Flash of Invisible Text)
FOUT(Flash of Unstyled Text)大意就是在字體加載完成前,瀏覽器會顯示font-family
的順序字體
當加載完成後,纔會替換成定義的字體,設置以下:
@font-face {
...
font-display: swap;
...
}
複製代碼
這樣的效果,就是會在頁面中看到的一個字體替換的效果😂
而後我想的是,有沒有什麼辦法能夠判斷字體加載完成了呢?
安裝:
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
的動畫,這樣效果就比較好了😎
webfont:www.webfont.com/
找到的一個方式,沒有實際用過,不知道效果咋樣,有興趣的能夠試試。
感謝支持。若不足之處,歡迎你們指出,共勉。
若是以爲不錯,記得 點贊,謝謝你們 😂
本文章採用知識共享署名-非商業性使用-相同方式共享 4.0 國際許可協議進行許可。