成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

在Vue.js中加載字體的優秀做法(適應于其他靜態資源)

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

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

正確聲明font-face的字體

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

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

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

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

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

預加載字體

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

  1. <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. <link rel="preconnect" href="https://fonts.gstatic.com"> 
  2. ... 
  3. <link href="https://fonts.googleapis.com/css2?family=Roboto&display=swap" rel="stylesheet"> 

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

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

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

使用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:

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

  1. cd pwa-app 
  2. yarn serve 

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

  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來配置service worker和它控制的元素、要使用的緩存策略以及其他必要的配置。

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

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

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

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

  1. yarn build 

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

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

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

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

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

結論

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

 

責任編輯:趙寧寧 來源: 今日頭條
相關推薦

2020-08-30 14:32:57

Vue.jsJavaScript前端

2017-09-27 16:44:23

前端

2019-10-11 09:59:55

開發者技能工具

2020-03-16 08:35:11

vue開發組件

2017-07-14 10:10:08

Vue.jsMixin

2021-04-17 18:24:04

Vue.js嵌套路由前端

2021-09-27 09:04:40

Vue.js代碼庫開發人員

2021-09-27 10:48:42

開發技能代碼

2018-04-04 10:32:13

前端JavascriptVue.js

2016-11-04 19:58:39

vue.js

2017-07-04 17:55:37

Vue.js插件開發

2022-04-01 10:41:09

Vue.js開發工具

2020-09-16 06:12:30

Vue.js 3.0Suspense組件前端

2017-08-30 17:10:43

前端JavascriptVue.js

2018-07-10 15:35:33

Vue前端架構

2021-01-04 08:04:51

JS 變量JavaScript

2022-01-19 22:18:56

Vue.jsVue SPA開發

2017-07-11 18:00:21

vue.js數據組件

2017-07-20 11:18:22

Vue.jsMVVMMVC

2024-05-13 08:04:26

Vue.jsWeb應用程序
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 美女久久久 | 免费看a | 欧美最猛黑人 | 亚洲国产一区视频 | 久久久成 | 亚洲一区二区在线播放 | www.日日夜夜 | 九九久久久 | 91文字幕巨乱亚洲香蕉 | 欧美视频日韩 | 在线啊v| 97成人免费 | 亚洲免费在线播放 | 天天干天天玩天天操 | 91精品国产综合久久精品 | av资源中文在线 | 成人av电影在线观看 | 国产精品免费一区二区三区 | 久久久久久免费毛片精品 | 日韩精品免费 | 国产亚洲精品久久19p | 亚洲69p| 欧洲一区二区三区 | 久久国产欧美日韩精品 | 男人电影天堂 | 亚洲精品www久久久久久广东 | 日本二区在线观看 | 狠狠操天天干 | 亚洲精品成人在线 | 天天影视亚洲综合网 | 四虎影院美女 | 欧美午夜一区二区三区免费大片 | 韩日免费视频 | 国产草草视频 | 久久国| 成人在线一区二区三区 | 久色网| 精品欧美二区 | 国产精品日日做人人爱 | 国产亚洲精品综合一区 | 国产成人精品亚洲日本在线观看 |