溫馨提示×

溫馨提示×

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

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

HTML5中使用rel屬性預(yù)加載功能的方法

發(fā)布時間:2020-09-14 15:02:09 來源:億速云 閱讀:113 作者:小新 欄目:web開發(fā)

小編給大家分享一下HTML5中使用rel屬性預(yù)加載功能的方法,希望大家閱讀完這篇文章后大所收獲,下面讓我們一起去探討吧!

在HTML5中,有個很有用但常被忽略的特性,就是預(yù)先加載(prefetch),它的原理是:
利用瀏覽器的空閑時間去先下載用戶指定需要的內(nèi)容,然后緩存起來,這樣用戶下次加載時,就直接從緩存中取出來,效率就快了.

舉個例子說明:比如要預(yù)先加載某個頁面,可以這樣:

<link rel="prefetch" href="http://www.example.com/"> <!-- Firefox -->

但如果是google的話,要用另外的一個名稱,即:

<link rel="prerender" href="http://www.example.com/"> <!-- Chrome -->

即使在不支持的瀏覽器,用了這個特性其實是不會出錯的,只不過瀏覽器解析不到而已, 所以,如果你感覺能有辦法預(yù)先預(yù)測到用戶期望點的頁面(比如用戶看最新的受歡迎的熱圖,他 可能看了第一頁后,會繼續(xù)看下一頁,這個時候就可以用預(yù)先加載這個特性了).比如 :

<link rel="prefetch" href="<?php echo get_next_posts_page_link(); ?>">

而單獨取一張圖片也是可以的,比如:

<link rel="prefetch" href="/images/test.jpg"/>

有了瀏覽器緩存,為何還需要預(yù)加載?

1.用戶可能是第一次訪問網(wǎng)站,此時還無緩存
2.用戶可能清空了緩存
3.緩存可能已經(jīng)過期,資源將重新加載
4.用戶訪問的緩存文件可能不是最新的,需要重新加載
5.Chrome 的預(yù)加載技術(shù)

現(xiàn)在的 chrome 聰明到根據(jù)你的瀏覽記錄,預(yù)測到你可能訪問或搜索哪些網(wǎng)站,在你打開網(wǎng)站之前就加載好了一些資源了。
舉個栗子,當你在搜索框輸入 "amaz" 時,它猜測到你可能要訪問 amazon.com,可能就幫你加載了這個網(wǎng)站的一些資源。
如果這個預(yù)測算法精準的話,就能大大地提高用戶的瀏覽體驗了。

DNS prefetch
我們知道,當我們訪問一個網(wǎng)站如 www.amazon.com 時,需要將這個域名先轉(zhuǎn)化為對應(yīng)的 IP 地址,這是一個非常耗時的過程。
DNS prefetch 分析這個頁面需要的資源所在的域名,瀏覽器空閑時提前將這些域名轉(zhuǎn)化為 IP 地址,真正請求資源時就避免了上述這個過程的時間.

<meta http-equiv='x-dns-prefetch-control' content='on'>  
<link rel='dns-prefetch' href='http://g-ecx.images-amazon.com'>  
<link rel='dns-prefetch' href='http://z-ecx.images-amazon.com'>  
<link rel='dns-prefetch' href='http://ecx.images-amazon.com'>  
<link rel='dns-prefetch' href='http://completion.amazon.com'>  
<link rel='dns-prefetch' href='http://fls-na.amazon.com'>

應(yīng)用場景1:我們的資源存在在不同的 CDN 中,那提前聲明好這些資源的域名,就可以節(jié)省請求發(fā)生時產(chǎn)生的域名解析的時間。
應(yīng)用場景2:如果我們知道用戶接下來的操作一定會發(fā)起一起資源的請求,那就可以將這個資源進行 DNS-Prefetch,加強用戶體驗。

Resource prefetch
在 Chrome 下,我們可以用 link標簽聲明特定文件的預(yù)加載:

<link rel='subresource' href='critical.js'>  
<link rel='subresource' href='main.css'>  
<link rel='prefetch' href='secondary.js'>

在 Firefox 中或用 meta 標簽聲明:

<meta http-equiv="Link" content="<critical.js>; rel=prefetch">

rel='subresource' 表示當前頁面必須加載的資源,應(yīng)該放到頁面最頂端先加載,有最高的優(yōu)先級。
rel='prefetch' 表示當 subresource 所有資源都加載完后,開始預(yù)加載這里指定的資源,有最低的優(yōu)先級。
注意:只有可緩存的資源才進行預(yù)加載,否則浪費資源!

Pre render
前面說到的預(yù)解析DNS、預(yù)加載資源已經(jīng)夠強悍了有木有,可還有更厲害的預(yù)渲染(Pre-rendering)!
預(yù)渲染意味著我們提前加載好用戶即將訪問的下一個頁面,否則進行預(yù)渲染這個頁面將浪費資源,慎用!

<link rel='prerender' href='http://www.pagetoprerender.com'>

rel='prerender' 表示瀏覽器會幫我們渲染但隱藏指定的頁面,一旦我們訪問這個頁面,則秒開了!
在 Firefox 中或用 rel='next' 來聲明

<link rel="next" href="http://www.pagetoprerender.com">

不是所有的資源都可以預(yù)加載

當資源為以下列表中的資源時,將阻止預(yù)渲染操作:
1.URL 中包含下載資源
2.頁面中包含音頻、視頻
3.POST、PUT 和 DELETE 操作的 ajax 請求
4.HTTP 認證(Authentication)
5.HTTPS 頁面
6.含惡意軟件的頁面
7.彈窗頁面
8.占用資源很多的頁面
9.打開了 chrome developer tools 開發(fā)工具

手動觸發(fā)預(yù)渲染操作

在 head 中強勢插入 link[rel='prerender'] 即可:

var hint =document.createElement("link")   
hint.setAttribute(“rel”,”prerender”)   
hint.setAttribute(“href”,”next-page.html”)   
document.getElementsByTagName(“head”)[0].appendChild(hint)

看完了這篇文章,相信你對HTML5中使用rel屬性預(yù)加載功能的方法有了一定的了解,想了解更多相關(guān)知識,歡迎關(guān)注億速云行業(yè)資訊頻道,感謝各位的閱讀!

向AI問一下細節(jié)

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

AI