日本综合一区二区|亚洲中文天堂综合|日韩欧美自拍一区|男女精品天堂一区|欧美自拍第6页亚洲成人精品一区|亚洲黄色天堂一区二区成人|超碰91偷拍第一页|日韩av夜夜嗨中文字幕|久久蜜综合视频官网|精美人妻一区二区三区

RELATEED CONSULTING
相關(guān)咨詢(xún)
選擇下列產(chǎn)品馬上在線(xiàn)溝通
服務(wù)時(shí)間:8:30-17:00
你可能遇到了下面的問(wèn)題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營(yíng)銷(xiāo)解決方案
在Vue.js中加載字體的優(yōu)秀做法(適應(yīng)于其他靜態(tài)資源)

添加字體不應(yīng)該對(duì)性能產(chǎn)生負(fù)面影響。在本文中,我們將探討在 Vue 應(yīng)用程序中加載字體的優(yōu)秀實(shí)踐。

正確聲明font-face的字體

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

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

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

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

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

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

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

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

預(yù)加載字體

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

 
 
 
 
  1.  

rel = “preload” 指示瀏覽器盡快開(kāi)始獲取資源,as = “font” 告訴瀏覽器這是一種字體,因此它優(yōu)先處理請(qǐng)求。還要注意 crossorigin="anonymous",因?yàn)槿绻麤](méi)有這個(gè)屬性,預(yù)加載的字體會(huì)被瀏覽器丟棄。這是因?yàn)闉g覽器是以匿名方式獲取字體的,所以使用這個(gè)屬性就可以匿名請(qǐng)求。

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

使用link = preconnect托管字體

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

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

 
 
 
 
  1.  
  2. ... 
  3.  

這樣就可以建立與原點(diǎn)https://fonts.gstatic.com 的初始連接,當(dāng)瀏覽器需要從原點(diǎn)獲取資源時(shí),連接已經(jīng)建立。從下圖中可以看出兩者的區(qū)別。

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

在這里,你會(huì)發(fā)現(xiàn)DNS查找、初始連接和SSL所花費(fèi)的時(shí)間已經(jīng)不存在了,因?yàn)榍懊嬉呀?jīng)進(jìn)行了連接。

使用service workers緩存字體

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

要開(kāi)始使用Vue構(gòu)建PWA,請(qǐng)使用vue-cli工具生成一個(gè)新項(xiàng)目:

 
 
 
 
  1. vue create pwa-app 

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

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

 
 
 
 
  1. cd pwa-app 
  2. yarn serve 

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

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

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

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

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

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

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

 
 
 
 
  1. yarn build 

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

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

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

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

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

結(jié)論

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


文章標(biāo)題:在Vue.js中加載字體的優(yōu)秀做法(適應(yīng)于其他靜態(tài)資源)
文章起源:http://www.dlmjj.cn/article/dhhicdo.html