溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

怎么在Vue.js應(yīng)用程序中加載字體

發(fā)布時間:2021-09-07 09:05:41 來源:億速云 閱讀:299 作者:chen 欄目:開發(fā)技術(shù)

這篇文章主要介紹“怎么在Vue.js應(yīng)用程序中加載字體”,在日常操作中,相信很多人在怎么在Vue.js應(yīng)用程序中加載字體問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”怎么在Vue.js應(yīng)用程序中加載字體”的疑惑有所幫助!接下來,請跟著小編一起來學(xué)習(xí)吧!

正確聲明font-face的字體

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

/root   public/     fonts/       Roboto/         Roboto-Regular.woff2         Roboto-Regular.woff     index.html   src/     assets/       main.css     components/     router/     store/     views/

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

// 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  作為值可以讓瀏覽器使用最合適的策略來顯示字體。這取決于一些因素,如網(wǎng)絡(luò)速度、設(shè)備類型、閑置時間等。

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

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

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

預(yù)加載字體

一旦你的自定義字體被聲明,你可以使用 告訴瀏覽器提前預(yù)加載字體。在 public/index.html  中,添加以下內(nèi)容:

<link rel="preload" as="font" href="./fonts/Roboto/Roboto-Regular.woff2" type="font/woff2" crossorigin="anonymous">

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

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

使用link = preconnect托管字體

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

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

<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  的初始連接,當(dāng)瀏覽器需要從原點獲取資源時,連接已經(jīng)建立。從下圖中可以看出兩者的區(qū)別。

怎么在Vue.js應(yīng)用程序中加載字體

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

怎么在Vue.js應(yīng)用程序中加載字體

在這里,你會發(fā)現(xiàn)DNS查找、初始連接和SSL所花費的時間已經(jīng)不存在了,因為前面已經(jīng)進(jìn)行了連接。

怎么在Vue.js應(yīng)用程序中加載字體

使用service workers緩存字體

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

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

vue create pwa-app

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

怎么在Vue.js應(yīng)用程序中加載字體

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

cd pwa-app yarn serve

你會注意到在 src 目錄下有一個文件 registerServiceWorker,其中包含了默認(rèn)的配置。在項目的根目錄下,如果  vue.config.js 不存在,請創(chuàng)建它,如果存在,請?zhí)砑右韵聝?nèi)容:

// vue.config.js module.exports = {   pwa: {     workboxOptions: {       skipWaiting: true,       clientsClaim: true,     }   } }

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

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

接下來,我們將自定義字體添加到 public 目錄。我有以下結(jié)構(gòu):

root/   public/     index.html     fonts/       Roboto/         Roboto-Regular.woff         Roboto-Regular.woff2

一旦完成了Vue應(yīng)用程序的開發(fā),就可以通過從終端運行以下命令來構(gòu)建它:

yarn build

這將結(jié)果輸出到 dist 文件夾中。如果你檢查文件夾的內(nèi)容,你會注意到一個類似于

precache-manifest.1234567890.js 的文件。它包含了要緩存的資產(chǎn)列表,這只是一個包含修訂版和URL的鍵值對的列表。

self.__precacheManifest = (self.__precacheManifest || []).concat([   {     "revision": "3628b4ee5b153071e725",     "url": "/fonts/Roboto/Roboto-Regular.woff2"   },   ... ]);

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

怎么在Vue.js應(yīng)用程序中加載字體

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

結(jié)論

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

到此,關(guān)于“怎么在Vue.js應(yīng)用程序中加載字體”的學(xué)習(xí)就結(jié)束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學(xué)習(xí),快去試試吧!若想繼續(xù)學(xué)習(xí)更多相關(guān)知識,請繼續(xù)關(guān)注億速云網(wǎng)站,小編會繼續(xù)努力為大家?guī)砀鄬嵱玫奈恼拢?/p>

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI