国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

<link>標簽的幾個用法,幫助提高頁面性能

tracymac7 / 2792人閱讀

摘要:最常見的用法,是用來鏈接一個外部的樣式表,比如標簽還能做一些其他的事情,來幫助我們提高頁面性能。可以幫助我們提高頁面的性能。

寫在前面
本文首發于公眾號:符合預期的CoyPan

HTML元素規定了外部資源與當前文檔的關系。最常見的用法,是用來鏈接一個外部的樣式表,比如:

link標簽還能做一些其他的事情,來幫助我們提高頁面性能。

link標簽的使用

來看一下link標簽除了鏈接外部樣式表之外的一些使用場景。

DNS Prefetch

DNS預解析。

這個大多數人都知道,用法也很簡單:


DNS解析,簡單來說就是把域名轉化為ip地址。我們在網頁里使用域名請求其他資源的時候,都會先被轉化為ip地址,再發起鏈接。dns-prefeth使得轉化工作提前進行了,縮短了請求資源的耗時。

什么時候使用呢?當我們頁面中使用了其他域名的資源時,比如我們的靜態資源都放在cdn上,那么我們可以對cdn的域名進行預解析。瀏覽器的支持情況也不錯。

Preconnect

預鏈接。

使用方法如下:


我們訪問一個站點時,簡單來說,都會經過以下的步驟:

DNS解析

TCP握手

如果為Https站點,會進行TLS握手

使用preconnect后,瀏覽器會針對特定的域名,提前初始化鏈接(執行上述三個步驟),節省了我們訪問第三方資源的耗時。需要注意的是,我們一定要確保preconnect的站點是網頁必需的,否則會浪費瀏覽器、網絡資源。

瀏覽器的支持情況也不錯:

Prefetch

預拉取。

使用方法如下:


link標簽里的as參數可以有以下取值:

audio: 音頻文件
video: 視頻文件  
Track: 網絡視頻文本軌道 
script: javascript文件
style: css樣式文件
font: 字體文件   
image: 圖片   
fetch: XHR、Fetch請求
worker: Web workers
embed: 多媒體請求 
object:  多媒體請求
document: 網頁

預拉取用于標識從當前網站跳轉到下一個網站可能需要的資源,以及本網站應該獲取的資源。這樣可以在將來瀏覽器請求資源時提供更快的響應。

如果正確使用了預拉取,那么用戶在從當前頁面前往下一個頁面時,可以很快得到響應。但是如果錯誤地使用了預拉取,那么瀏覽器就會下載額外不需要的資源,影響頁面性能,并且造成網絡資源浪費。

這里需要注意的是,使用了prefetch,資源僅僅被提前下載,下載后不會有任何操作,比如解析資源。

Prerender

預渲染。

prerender比prefetch更進一步。不僅僅會下載對應的資源,還會對資源進行解析。解析過程中,如果需要其他的資源,可能會直接下載這些資源。這樣,用戶在從當前頁面跳轉到目標頁面時,瀏覽器可以更快的響應。

瀏覽器的支持情況如下:

Resource Hints

上面的四種用法,其實就是:Resource Hints

Resource Hints ,翻譯過來是【資源提示】。w3c的概括為:

This specification defines the dns-prefetch, preconnect, prefetch, and prerender relationships of the HTML Link Element (). These primitives enable the developer, and the server generating or delivering the resources, to assist the user agent in the decision process of which origins it should connect to, and which resources it should fetch and preprocess to improve page performance.

此規范定義HTML鏈接元素()的DNS預取、預連接、預取和預渲染關系。這些原語使開發人員和生成或傳遞資源的服務器能夠幫助用戶代理決定應該連接到哪個源,以及應該獲取哪些資源,并進行預處理以提高頁面性能。

更多詳細內容,可以在w3c的草案中查看:https://www.w3.org/TR/resourc...

Resource Hints使用方法

除了上面介紹的使用link標簽的使用方法,還可以直接通過http header的方式使用。例如可以使用下面的header:

Link: ; rel=dns-prefetch
Link: ; rel=preconnect
Link: ; rel=prerender;
Link: ; rel=prefetch; as=image;

還可以在javascript使用:

var hint = document.createElement("link");
hint.rel = "prefetch";
hint.as = "document";
hint.href = "/article/part3.html";
document.head.appendChild(hint);
Resource Hints總結

上文介紹了DNS Prefetch,Preconnect, Prefetch,Prerender。這四種hint的功能逐漸遞進:

Dns Prefetch進行DNS預查詢。

Preconnect進行預鏈接。在一些重定向技術中,Preconnect可以讓瀏覽器和最終目標源更早建立連接。

Prefetch進行預下載。比如說,我們可以根據用戶行為猜測其下一步操作,然后動態預獲取所需資源,并且不用擔心該資源被解析(執行)而影響頁面當前功能。

Prerender不僅僅提前下載資源,還會提前直接解析(執行)資源。如果我們對下一個頁面進行Prerender,用戶在打開下一個頁面時,就會感覺很流暢了。

需要注意的是,瀏覽器對于Resource Hints的實現并不是想象中的那樣簡單直接。Resource Hints只是一些『提示』,瀏覽器可以采用我們的提示,但是具體怎么實現還是由瀏覽器自己來決定的。比如,如果當前CPU壓力大,網絡阻塞時,你使用了Prefetch,那么瀏覽器可能僅僅會只對dns進行預解析,并不會下載資源。

寫在后面

本文介紹了link標簽的四種使用方法,最終引出了Resource Hints的概念。Resource Hints可以幫助我們提高頁面的性能。但是這只是理論上的,真正的收益還需要在實際業務中去探索、驗證。

符合預期。

文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。

轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/104371.html

相關文章

  • &lt;link&gt;標簽幾個用法幫助提高頁面性能

    摘要:最常見的用法,是用來鏈接一個外部的樣式表,比如標簽還能做一些其他的事情,來幫助我們提高頁面性能。可以幫助我們提高頁面的性能。 寫在前面 本文首發于公眾號:符合預期的CoyPan HTML 中元素規定了外部資源與當前文檔的關系。最常見的用法,是用來鏈接一個外部的樣式表,比如: link標簽還能做一些其他的事情,來幫助我們提高頁面性能。 link標簽的使用 來看一下link標簽除了鏈接外...

    Airy 評論0 收藏0
  • &lt;head&gt;標簽中的奧秘

    摘要:作為一名前端開發,我竟一直不知道標簽中的秘密。告訴瀏覽器使用最新的引擎渲染網頁,而則告訴瀏覽器激活谷歌瀏覽器內嵌框架,是推出的一款免費的專用插件。這一機制使得資源可以更早的被加載并可用,更不易阻塞頁面的初步渲染,進而提升性能。 作為一名前端開發,我竟一直不知道標簽中的秘密。 有幸接觸到這個知識點,覺得不能自己獨享這份喜悅,特此分享給大家。 舉幾個例子: 京東金融的部分剖析 showIm...

    Thanatos 評論0 收藏0
  • Vue編程三部曲之模型樹優化實戰代碼

      實踐是所有展示最好的方法,因此我覺得可以不必十分細致的,但我們的展示卻是整體的流程、輸入和輸出?,F在我們就看看Vue 的指令、內置組件等。也就是第二篇,模型樹優化。  分析了 Vue 編譯三部曲的第一步,「如何將 template 編譯成 AST ?」上一篇已經介紹,但我們還是來總結回顧下,parse 的目的是將開發者寫的 template 模板字符串轉換成抽象語法樹 AST ,AST 就這里...

    3403771864 評論0 收藏0
  • 教你20行python代碼實現編輯永久免費pdf工具

      小編寫這篇文章的主要目的,主要是給大家介紹一下關于python代碼實現pdf編輯免費pdf工具相關知識的解答。  PDF是在日常生活中使用范圍還是比較的廣泛的,很多的文檔都是PDF格式。格式穩定是他的一個優勢,使得我們在打印、分享、傳輸過程中能夠最優的保持原有色彩和格式?! DF各種各樣的的版本是比較的多的,它在格式的穩定性方面雖然具有很大優勢。但是,在可編輯性方面卻為使用者引入了另外一個困...

    89542767 評論0 收藏0
  • 對象存儲 性能數據與分析 US3

    摘要:缺陷雖然目前確實能給基于存儲的大數據方案帶來進一步性能提高,但目前的設計還是有不少缺陷,主要在體現在幾個方面單點架構使得可靠性降低。性能數據與分析本篇目錄測試環境測試數據us3vmds基于Go語言開發,自帶了Go的profile功能,通過以下命令,可以在指定地址開啟Go的運行時性能分析HTTP服務:? bin ? us3vmds pprof --open 127.0.0.1 8081 ? ...

    ernest.wang 評論0 收藏140

發表評論

0條評論

tracymac7

|高級講師

TA的文章

閱讀更多
最新活動
閱讀需要支付1元查看
<