一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

node.js|vue.js|jquery|angularjs|React|json|js教程|

服務器之家 - 編程語言 - JavaScript - vue.js - 在Vue.js中加載字體的正確方法

在Vue.js中加載字體的正確方法

2022-02-24 16:36程序員張張 vue.js

這篇文章主要介紹了在Vue.js中加載字體的正確方法,本文通過實例圖文相結合給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下

添加字體不應該對性能產生負面影響。在本文中,我們將探討在 Vue 應用程序中加載字體的最佳實踐。

在Vue.js中加載字體的正確方法

正確聲明 font-face 的字體

確保正確聲明字體是加載字體的重要方面。這是通過使用 font-face 屬性來聲明你選擇的字體來實現的。在你的 Vue 項目中,這個聲明可以在你的根 CSS 文件中完成。在進入這個問題之前,我們先來看看 Vue 應用的結構。

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
/root
 public/
 fonts/
 Roboto/
 Roboto-Regular.woff2
 Roboto-Regular.woff
 index.html
 src/
 assets/
 main.css
 components/
 router/
 store/
 views/
 main.js

我們可以像這樣在 main.css 中進行 font-face 聲明:

?
1
2
3
4
5
6
7
8
9
10
11
12
// src/assets/main.css
 
@font-face {
 font-family: "Roboto";
 font-weight: 400;
 font-style: normal;
 font-display: auto;
 unicode-range: U+000-5FF;
 src: local("Roboto"),
 url("/fonts/Roboto/Roboto-Regular.woff2") format("woff2"),
 url("/fonts/Roboto/Roboto-Regular.woff") format("woff");
}

首先要注意的是 font-display:auto 。使用 auto 作為值可以讓瀏覽器使用最合適的策略來顯示字體。這取決于一些因素,如網絡速度、設備類型、閑置時間等。

要想更多地控制字體的加載方式,你應該使用 font-display: block ,它指示瀏覽器短暫地隱藏文本,直到字體完全下載完畢。其他可能的值有 swap 、 fallback 和 optional 。你可以在 這里 閱讀更多關于它們的信息。

需要注意的是 unicode-range: U+000-5FF ,它指示瀏覽器只加載所需的字形范圍(U+000 - U+5FF)。你還想使用 woff 和 woff2 字體格式,它們是經過優化的格式,可以在大多數現代瀏覽器中使用。

另外需要注意的是 src 順序。首先,我們檢查字體的本地副本是否可用( local("Roboto”) )并使用它。很多 Android 設備都預裝了 Roboto,在這種情況下,我們將使用預裝的副本。如果沒有本地副本,則在瀏覽器支持的情況下繼續下載 woff2 格式。否則,它會跳至支持的聲明中的下一個字體。

預加載字體

一旦你的自定義字體被聲明,你可以使用 <link rel="preload"> 告訴瀏覽器提前預加載字體。在 public/index.html 中,添加以下內容:

?
1
2
3
4
5
6
7
<link
 rel="preload"
 as="font"
 href="./fonts/Roboto/Roboto-Regular.woff2"
 type="font/woff2"
 crossorigin="anonymous"
/>

rel = “preload” 指示瀏覽器盡快開始獲取資源, as = “font” 告訴瀏覽器這是一種字體,因此它優先處理請求。還要注意 crossorigin=“anonymous" ,因為如果沒有這個屬性,預加載的字體會被瀏覽器丟棄。這是因為瀏覽器是以匿名方式獲取字體的,所以使用這個屬性就可以匿名請求。

使用 link=preload 可以增加自定義字體在需要之前被下載的機會。這個小調整大大加快了字體的加載時間,從而加快了您的 Web 應用程序中的文本渲染。

使用 link = preconnect 托管字體

當使用Google fonts 等網站的托管字體時,你可以通過使用 link=preconnect 來獲得更快的加載時間。它告訴瀏覽器提前建立與域名的連接。

如果您使用的是 Google 字體提供的 Roboto 字體,則可以在 public/index.html 中執行以下操作:

?
1
2
3
4
5
6
<link rel="preconnect" href="https://fonts.gstatic.com" />
...
<link
 href="https://fonts.googleapis.com/css2?family=Roboto&display=swap"
 rel="stylesheet"
/>

這樣就可以建立與原點 https://fonts.gstatic.com 的初始連接,當瀏覽器需要從原點獲取資源時,連接已經建立。從下圖中可以看出兩者的區別。

在Vue.js中加載字體的正確方法

當加載字體時沒有使用 link=preconnect 時,你可以看到連接所需的時間(DNS 查找、初始連接、SSL 等)。當像這樣使用 link=preconnect 時,結果看起來非常不同。

在Vue.js中加載字體的正確方法

在這里,你會發現 DNS 查找、初始連接和 SSL 所花費的時間已經不存在了,因為前面已經進行了連接。

在Vue.js中加載字體的正確方法

使用 service workers 緩存字體

字體是靜態資源,變化不大,所以它們是緩存的好候選。理想情況下,您的 Web 服務器應該為字體設置一個較長的 max-age expires 頭,這樣瀏覽器緩存字體的時間就會更長。如果你正在構建一個漸進式網絡應用(PWA),那么你可以使用 service workers 來緩存字體,并直接從緩存中為它們提供服務。

要開始使用 Vue 構建 PWA,請使用 vue-cli 工具生成一個新項目:

?
1
vue create pwa-app

選擇 Manually select features 選項,然后選擇 Progressive Web App (PWA) Support :

在Vue.js中加載字體的正確方法

這些就是我們生成 PWA 模板所需要的唯一東西。完成后,你就可以把目錄改為 pwa-app ,然后為 app 服務。

?
1
2
cd pwa-app
yarn serve

你會注意到在 src 目錄下有一個文件 registerServiceWorker ,其中包含了默認的配置。在項目的根目錄下,如果 vue.config.js 不存在,請創建它,如果存在,請添加以下內容:

?
1
2
3
4
5
6
7
8
9
// vue.config.js
module.exports = {
 pwa: {
 workboxOptions: {
 skipWaiting: true,
 clientsClaim: true,
 },
 },
};

vue-cli 工具使用PWA plugin 生成 service worker。在底層,它使用 Workbox 來配置 service worker 和它控制的元素、要使用的緩存策略以及其他必要的配置。

在上面的代碼片段中,我們要確保我們的應用程序始終由 service worker 的最新版本控制。這是必要的,因為它確保我們的用戶總是查看應用程序的最新版本。您可以簽出 Workbox 配置文檔,以獲得對生成的 service worker 行為的更多控制。

接下來,我們將自定義字體添加到 public 目錄。我有以下結構:

?
1
2
3
4
5
6
7
root/
 public/
 index.html
 fonts/
 Roboto/
 Roboto-Regular.woff
 Roboto-Regular.woff2

一旦完成了 Vue 應用程序的開發,就可以通過從終端運行以下命令來構建它:

?
1
yarn build

這將結果輸出到 dist 文件夾中。如果你檢查文件夾的內容,你會注意到一個類似于 precache-manifest.1234567890.js 的文件。它包含了要緩存的資產列表,這只是一個包含修訂版和 URL 的鍵值對的列表。

?
1
2
3
4
5
6
7
self.__precacheManifest = (self.__precacheManifest || []).concat([
 {
 "revision": "3628b4ee5b153071e725",
 "url": "/fonts/Roboto/Roboto-Regular.woff2"
 },
 ...
]);

public/ 文件夾中的所有內容都是默認緩存的,其中包括自定義字體。有了這個地方,你可以用像 service 這樣的包來 serve 你的應用程序,或者把 dist 文件夾托管在 web 服務器上查看結果。你可以在下面找到一個應用程序的截圖。

在Vue.js中加載字體的正確方法

在隨后的訪問中,字體是從緩存中加載的,這可以加快應用程序的加載時間。

結論

在這篇文章中,我們研究了在 Vue 應用程序中加載字體時應用的一些最佳實踐。使用這些實踐將確保你提供的字體看起來不錯,而不影響應用的性能。

到此這篇關于在Vue.js中加載字體的正確方法的文章就介紹到這了,更多相關vue.js 加載字體內容請搜索服務器之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持服務器之家!

原文鏈接:https://blog.zhangbing.site/2021/04/07/best-practices-for-loading-fonts-in-vue/

延伸 · 閱讀

精彩推薦
  • vue.js用vite搭建vue3應用的實現方法

    用vite搭建vue3應用的實現方法

    這篇文章主要介紹了用vite搭建vue3應用的實現方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下...

    Asiter7912022-01-22
  • vue.js梳理一下vue中的生命周期

    梳理一下vue中的生命周期

    看過很多人講vue的生命周期,但總是被繞的云里霧里,尤其是自學的同學,可能js的基礎也不是太牢固,聽起來更是吃力,那我就已個人之淺見,以大白話...

    CRMEB技術團隊7992021-12-22
  • vue.jsVue多選列表組件深入詳解

    Vue多選列表組件深入詳解

    這篇文章主要介紹了Vue多選列表組件深入詳解,這個是vue的基本組件,有需要的同學可以研究下...

    yukiwu6752022-01-25
  • vue.jsVue2.x-使用防抖以及節流的示例

    Vue2.x-使用防抖以及節流的示例

    這篇文章主要介紹了Vue2.x-使用防抖以及節流的示例,幫助大家更好的理解和學習使用vue框架,感興趣的朋友可以了解下...

    Kyara6372022-01-25
  • vue.jsVue項目中實現帶參跳轉功能

    Vue項目中實現帶參跳轉功能

    最近做了一個手機端系統,其中遇到了父頁面需要攜帶參數跳轉至子頁面的問題,現已解決,下面分享一下實現過程,感興趣的朋友一起看看吧...

    YiluRen丶4302022-03-03
  • vue.js詳解vue 表單綁定與組件

    詳解vue 表單綁定與組件

    這篇文章主要介紹了vue 表單綁定與組件的相關資料,幫助大家更好的理解和學習使用vue框架,感興趣的朋友可以了解下...

    Latteitcjz6432022-02-12
  • vue.jsVue2.x 項目性能優化之代碼優化的實現

    Vue2.x 項目性能優化之代碼優化的實現

    這篇文章主要介紹了Vue2.x 項目性能優化之代碼優化的實現,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋...

    優小U9632022-02-21
  • vue.jsVue中引入svg圖標的兩種方式

    Vue中引入svg圖標的兩種方式

    這篇文章主要給大家介紹了關于Vue中引入svg圖標的兩種方式,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的...

    十里不故夢10222021-12-31
主站蜘蛛池模板: 青草免费在线观看 | 色琪琪原网站亚洲香蕉 | 美女扒开两腿露出尿口的视频 | 欧美一级片在线看 | 亚洲性夜| 91精品手机国产在线观 | 动漫jk美女被爆羞羞漫画 | a级亚洲片精品久久久久久久 | 双性肉文h | 毛片免费全部免费观看 | 日本性漫画 | 午夜视频在线网站 | 高清视频在线观看+免费 | 欧美男同videos | 日韩精品一区二区 | yy8090韩国日本三理论免费 | 国产精品久久久久久久久免费hd | 成人国产第一区在线观看 | 国内小情侣一二三区在线视频 | 奇米影视777最新在线 | 欧美人在线一区二区三区 | 久久re热在线视频精99 | 久草在线草a免费线看 | 香港三级系列在线播放 | 三级午夜宅宅伦不卡在线 | 亚洲 另类 欧美 变态屎尿 | 36美女厕所撒尿全过程 | 日本一在线中文字幕天堂 | 亚洲精品国产精麻豆久久99 | 窝窝午夜精品一区二区 | chinesespank打屁股| 火影小南被爆羞羞网站进入 | 亚洲大片免费看 | 久久精品动漫99精品动漫 | h卡通第一页 | 被黑人同学彻底征服全文小说阅读 | 亚洲国产欧美目韩成人综合 | 免费我看视频在线观看 | 欧美在线观看网址 | 99精品免费视频 | 国产免费色视频 |