前端優(yōu)化之Pre技術(shù)簡(jiǎn)介

Pre技術(shù):預(yù)加載技術(shù)。提供在不影響當(dāng)前頁(yè)面情況下,瀏覽器預(yù)加載資源的性能優(yōu)化方案惹盼。

比較出名的Pre是dns-prefetch,用于告知瀏覽器預(yù)先獲取指定的域名的DNS惫确,以便在使用時(shí)可以減少DNS查找逻锐。除了dns-prefetch外,還有幾個(gè)“不出名”的Prer技術(shù)雕薪,本文將對(duì)現(xiàn)有的幾個(gè)Pre技術(shù)做一個(gè)簡(jiǎn)單的介紹,這些技術(shù)都是使用link標(biāo)簽定義晓淀。

DNS Prefetch

就是上述提到的所袁,用于告知瀏覽器,盡可能預(yù)先解析指定域名的DNS凶掰。使用方式:

<link rel="dns-prefetch" href="http://the-domain-to-be-prefetched.com" />

至于兼容性燥爷,可以說(shuō)是目前為止所有的Pre技術(shù)里最好的了,具體可以查看http://caniuse.com/#search=dns-prefetch
IE是從IE9開始支持DNS Prefetch的懦窘,但是前翎,是從IE10開始支持dns-prefetch。IE9里畅涂,并不是使用dns-prefetch來(lái)定義一個(gè)DNS的預(yù)解析港华,而是使用prefetch。挺尷尬的午衰,因?yàn)閜refetch在w3規(guī)范里又被用到了另一個(gè)Pre技術(shù)立宜,下面會(huì)講到。臊岸。

Preconnect

預(yù)連接橙数。和DNS Prefetch類似,但是帅戒,更進(jìn)一步灯帮。它不僅要求瀏覽器預(yù)解析指定域名的DNS,還需要預(yù)先與服務(wù)器握手以及TLS協(xié)商(如果使用了HTTPS)。使用方式:

<link rel="preconnect" href="http://the-domain-to-be-preconnect.com" crossorigin="anonymous" />

兼容性查看http://caniuse.com/#search=preconnect
由于會(huì)與服務(wù)器握手钟哥,因此迎献,就需要確定“是否跨域”。和script類似瞪醋,帶crossorigin屬性忿晕,以告知瀏覽器如何處理跨域和cookie。

Prefetch

上述DNS Prefetch里提到過银受,IE9里使用的DNS Prefetch類型名是prefetch践盼,但是,這個(gè)類型名在規(guī)范里又被用于另外一個(gè)意圖宾巍。

Prefetch:預(yù)獲取咕幻,在Preconnect基礎(chǔ)上更進(jìn)一步,它要求瀏覽器獲取整個(gè)的指定資源顶霞,link[href]值指定的是某個(gè)具體資源肄程,而不是簡(jiǎn)單的一個(gè)域名了。除了和Preconnect一樣擁有rel选浑、hrefcrossorigin外蓝厌,還有as,可用于告知瀏覽器資源類型古徒,這個(gè)類型和MIME不一樣拓提,是一個(gè)統(tǒng)稱類型,比如:所有的圖片都是as="image"隧膘,JS的是as="script"代态,HTML的是 as="html"等,具體可以參考https://fetch.spec.whatwg.org/#concept-request-destination疹吃。使用方式:

<link rel="prefetch"  crossorigin as="script" />

as屬性并不是必須的蹦疑,但是建議加上,以便瀏覽器能更好的添加請(qǐng)求Header來(lái)優(yōu)化資源的獲取萨驶。

使用Prefetch歉摧,整個(gè)資源都會(huì)被加載,但是腔呜,瀏覽器不允許對(duì)資源預(yù)處理或執(zhí)行判莉,資源只是被提前加載,并緩存起來(lái)育谬,以便將來(lái)使用券盅。
兼容性查看http://caniuse.com/#search=prefetch

Prerender

預(yù)渲染。與Prefetch類似膛檀,瀏覽器會(huì)下載整個(gè)資源锰镀,但是娘侍,Prefetch不允許瀏覽器對(duì)資源做預(yù)處理和執(zhí)行,而Prerender則會(huì)告知瀏覽器泳炉,下載資源(HTML)并解析/執(zhí)行它憾筏,包括被解析資源的子資源,這意味著會(huì)下載該HTML中的圖片花鹅、樣式氧腰、腳本等等。
Prerender沒有as屬性刨肃,它下載的是HTML古拴,使用方式

<link rel="preconnect" href="http://the-domain-to-be-preconnect.com" />

由于不允許對(duì)當(dāng)前頁(yè)面產(chǎn)生影響,瀏覽器設(shè)置預(yù)渲染的頁(yè)面visibilityState屬性為hidden真友。
兼容性查看http://caniuse.com/#search=prerender
建議少用這個(gè)黄痪,太耗資源。而且盔然,查看上述兼容性桅打,你會(huì)看到Chrome 58里又把這個(gè)功能干掉了。愈案。挺尾。。站绪。潦嘶。

Preload

預(yù)加載。這是一個(gè)和Prefetch幾乎一模一樣的功能崇众,但是,其加載的資源適用的場(chǎng)景又完全不一樣航厚。使用方式只是將上述Prefetch中的prefetch改成preload顷歌。其他的完全一樣:

<link rel="preload"  crossorigin as="image" />

Prefetch*不同之處在于:

  1. Prefetch的優(yōu)先級(jí)很低,低到瀏覽器可以不加載
  2. Preload的優(yōu)先級(jí)很高幔睬,瀏覽器一定要加載
  3. Prefetch加載的資源用于將來(lái)某個(gè)頁(yè)面中(這意味著它可能壓根不會(huì)被用到)
  4. Preload加載的資源用于當(dāng)前頁(yè)面

所以眯漩,在使用prefetch還是preload時(shí)候,需要考慮上述的不同點(diǎn)麻顶,而不應(yīng)該盲目使用赦抖。[Preload以前叫Subresource]
兼容性查看http://caniuse.com/#search=preload

最后,上述Pre技術(shù)辅肾,除了Preload队萤,其他的Pre都可能“不被瀏覽器執(zhí)行”,這不是兼容性的問題矫钓,而是要尔,這些Pre都不是瀏覽器必須行為舍杜,瀏覽器會(huì)根據(jù)一定的策略決定是否Pre相應(yīng)的資源或操作,這些策略包括:CPU赵辕、內(nèi)存等的占用率既绩。

有空的話,我再另外寫個(gè)文章还惠,介紹一下具體使用Prefetch和Preload的優(yōu)化效果吧饲握。

P.S. 參考

  1. https://w3c.github.io/resource-hints/
  2. IE10 now supports LINK REL=dns-prefetch. In IE9, we only would perform DNS prefetch for LINK REL=prefetch as the dns-prefetch token was not yet defined. (see https://blogs.msdn.microsoft.com/ieinternals/2012/03/01/internet-explorer-10-consumer-preview-minor-changes-list/)
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市蚕键,隨后出現(xiàn)的幾起案子救欧,更是在濱河造成了極大的恐慌,老刑警劉巖嚎幸,帶你破解...
    沈念sama閱讀 216,997評(píng)論 6 502
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件颜矿,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡嫉晶,警方通過查閱死者的電腦和手機(jī)骑疆,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,603評(píng)論 3 392
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)替废,“玉大人箍铭,你說(shuō)我怎么就攤上這事∽盗停” “怎么了诈火?”我有些...
    開封第一講書人閱讀 163,359評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)状答。 經(jīng)常有香客問我冷守,道長(zhǎng),這世上最難降的妖魔是什么惊科? 我笑而不...
    開封第一講書人閱讀 58,309評(píng)論 1 292
  • 正文 為了忘掉前任拍摇,我火速辦了婚禮,結(jié)果婚禮上馆截,老公的妹妹穿的比我還像新娘充活。我一直安慰自己,他們只是感情好蜡娶,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,346評(píng)論 6 390
  • 文/花漫 我一把揭開白布混卵。 她就那樣靜靜地躺著,像睡著了一般窖张。 火紅的嫁衣襯著肌膚如雪幕随。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,258評(píng)論 1 300
  • 那天宿接,我揣著相機(jī)與錄音合陵,去河邊找鬼枢赔。 笑死,一個(gè)胖子當(dāng)著我的面吹牛拥知,可吹牛的內(nèi)容都是我干的踏拜。 我是一名探鬼主播,決...
    沈念sama閱讀 40,122評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼低剔,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼速梗!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起襟齿,我...
    開封第一講書人閱讀 38,970評(píng)論 0 275
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤姻锁,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后猜欺,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體位隶,經(jīng)...
    沈念sama閱讀 45,403評(píng)論 1 313
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,596評(píng)論 3 334
  • 正文 我和宋清朗相戀三年开皿,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了涧黄。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 39,769評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡赋荆,死狀恐怖笋妥,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情窄潭,我是刑警寧澤春宣,帶...
    沈念sama閱讀 35,464評(píng)論 5 344
  • 正文 年R本政府宣布,位于F島的核電站嫉你,受9級(jí)特大地震影響月帝,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜幽污,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,075評(píng)論 3 327
  • 文/蒙蒙 一嚷辅、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧油挥,春花似錦、人聲如沸款熬。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,705評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)贤牛。三九已至惋鹅,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間殉簸,已是汗流浹背闰集。 一陣腳步聲響...
    開封第一講書人閱讀 32,848評(píng)論 1 269
  • 我被黑心中介騙來(lái)泰國(guó)打工沽讹, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人武鲁。 一個(gè)月前我還...
    沈念sama閱讀 47,831評(píng)論 2 370
  • 正文 我出身青樓爽雄,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親沐鼠。 傳聞我的和親對(duì)象是個(gè)殘疾皇子挚瘟,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,678評(píng)論 2 354

推薦閱讀更多精彩內(nèi)容

  • 在這個(gè)前端用戶體驗(yàn)越來(lái)越重要的時(shí)代,你的頁(yè)面稍微有點(diǎn)卡頓饲梭,都難以挽留用戶乘盖。而作為一名有追求的前端,勢(shì)必要力所能及地...
    程序員小布的養(yǎng)生之道閱讀 1,045評(píng)論 0 50
  • 在這個(gè)前端用戶體驗(yàn)越來(lái)越重要的時(shí)代憔涉,你的頁(yè)面稍微有點(diǎn)卡頓订框,都難以挽留用戶。而作為一名有追求的前端兜叨,勢(shì)必要力所能及地...
    SCQ000閱讀 3,826評(píng)論 0 52
  • 網(wǎng)頁(yè)性能基礎(chǔ): http://www.alloyteam.com/2015/05/wang-ye-xing-nen...
    raincoco閱讀 1,658評(píng)論 0 0
  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理穿扳,服務(wù)發(fā)現(xiàn),斷路器浪腐,智...
    卡卡羅2017閱讀 134,654評(píng)論 18 139
  • “你十六歲喜歡上的人可能是你一輩子最難忘記的人纵揍。”駱駝小姐相信這句話议街,因?yàn)樗涣四莻€(gè)笑起來(lái)會(huì)露八顆牙齒的男孩泽谨。高...
    glare閱讀 850評(píng)論 2 3