成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

關(guān)于外部樣式表也許你不知道的事

wwq0327 / 1803人閱讀

摘要:如下圖所示,外部樣式表是否會(huì)阻塞解析先不要看答案,可以自己思考和實(shí)驗(yàn)一下通過如上圖所示,并沒有阻塞解析,因?yàn)闀r(shí)間線在之后。并且都支持事件回調(diào)處理,用于一些初始化工作。為了盡早地觸發(fā)事件,因?yàn)闀?huì)延遲事件觸發(fā)。

singsong: 文章中 demo 猛戳這里吧

??最新內(nèi)容請(qǐng)以github上的為準(zhǔn)??

在講解之前,先看一個(gè)問題。如下圖所示,外部樣式表是否會(huì)阻塞 HTML 解析(先不要看答案,可以自己思考和實(shí)驗(yàn)一下):


通過DevTools->network:


如上圖所示,indexcss.css 并沒有阻塞 HTML 解析,因?yàn)?DOMContentLoaded 時(shí)間線在 indexcss.css 之后。但如果在 indexcss.css 之后添加script 標(biāo)簽(不能為空),結(jié)果會(huì)一樣?


通過 DevTools->network:

如上圖所示,在 indexcss.css 之后添加 script 標(biāo)簽(不能為空)后,此時(shí) DOMContentLoaded 時(shí)間線位于 indexcss.css 之后。說明這里 indexcss.css 是阻塞 HTML 解析的。

參考相關(guān)資料,找到如下描述:
Style sheets on the other hand have a different model. Conceptually it seems that since style sheets don"t change the DOM tree, there is no reason to wait for them and stop the document parsing. There is an issue, though, of scripts asking for style information during the document parsing stage. If the style is not loaded and parsed yet, the script will get wrong answers and apparently this caused lots of problems. It seems to be an edge case but is quite common. Firefox blocks all scripts when there is a style sheet that is still being loaded and parsed. WebKit blocks scripts only when they try to access certain style properties that may be affected by unloaded style sheets.----Tali Garsiel

大概意思是:style-sheets 不會(huì)修改 DOM 樹,沒有理由為了解析 style-sheets 而阻塞文檔解析(即 style-sheets 不會(huì)阻塞文檔解析)。但如果在解析文檔過程中有腳本需要訪問樣式信息時(shí),為了保證訪問樣式信息的正確性。Firefox 會(huì)阻塞所有腳本直到 style-sheets 下載解析完為止。而 WebKit 只在訪問的樣式屬性沒有被加載解析時(shí),才會(huì)阻塞腳本。

也即 style-sheet 不會(huì)直接阻塞文檔解析,它只阻塞 script 的解析執(zhí)行,才導(dǎo)致 style-sheet 間接阻塞文檔解析。如果將 script 設(shè)置為非阻塞式的呢?可以通過為 script 標(biāo)簽設(shè)置 aysnc 特性來實(shí)現(xiàn)??赡苣銜?huì)疑問為什么不用 defer?

Both async and defer scripts begin to download immediately without pausing the parser and both support an optional onload handler to address the common need to perform initialization which depends on the script. The difference between async and defer centers around when the script is executed. Each async script executes at the first opportunity after it is finished downloading and before the window’s load event. This means it’s possible (and likely) that async scripts are not executed in the order in which they occur in the page. The defer scripts, on the other hand, are guaranteed to be executed in the order they occur in the page. That execution starts after parsing is completely finished, but before the document’s DOMContentLoaded event.

大概意思:asyncdefer 特性在腳本開始下載時(shí),都不會(huì)阻塞文檔解析。并且都支持 onload 事件回調(diào)處理,用于一些初始化工作。另外,兩者對(duì)內(nèi)聯(lián)腳本都無效,腳本中不能調(diào)用document.write()。而兩者的不同之處:帶有 async 特性的腳本會(huì)在腳本下載完后立即執(zhí)行,且在 load 事件之前,所以不能確保腳本在文檔中出現(xiàn)的順序來執(zhí)行。而帶有defer特性的腳本會(huì)在文檔解析完后按照在文檔中出現(xiàn)的順序來執(zhí)行,且在 DOMContentLoaded 事件之前。

因此,這里設(shè)置 async 特性,而不設(shè)置 defer 特性。為了盡早地觸發(fā) DOMContentLoaded 事件,因?yàn)?defer 會(huì)延遲 DOMContentLoaded 事件觸發(fā)。

為 script 標(biāo)簽添加 async 特性:

通過DevTools->network:


當(dāng)然,這里也可以通過媒體查詢 media讓 style-sheet 異步加載:

通過DevTools->network:

總結(jié):

style-sheet 默認(rèn)情況下是不會(huì)阻塞文檔解析。

style-sheet 只會(huì)阻塞 script 腳本解析執(zhí)行。因?yàn)?script 腳本需要訪問 style-sheet 樣式信息,為了確保樣式信息的正確性,因此 script 腳本需要等待 style-sheet 下載解析完。從而導(dǎo)致 style-sheet 間接地阻塞文檔解析。

style-sheet 可以通過媒體查詢 media來實(shí)現(xiàn)異步加載。

為 script 設(shè)置 aysnc 特性來實(shí)現(xiàn) script 異步加載,來加快文檔解析。

參考文章:

分析關(guān)鍵渲染路徑性能

Deciphering the Critical Rendering Path

How Browsers Work: Behind the scenes of modern web browsers

文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/52308.html

相關(guān)文章

  • 關(guān)于外部樣式也許你不知道的事

    摘要:如下圖所示,外部樣式表是否會(huì)阻塞解析先不要看答案,可以自己思考和實(shí)驗(yàn)一下通過如上圖所示,并沒有阻塞解析,因?yàn)闀r(shí)間線在之后。并且都支持事件回調(diào)處理,用于一些初始化工作。為了盡早地觸發(fā)事件,因?yàn)闀?huì)延遲事件觸發(fā)。 singsong: 文章中 demo 猛戳這里吧 ??最新內(nèi)容請(qǐng)以github上的為準(zhǔn)?? 在講解之前,先看一個(gè)問題。如下圖所示,外部樣式表是否會(huì)阻塞 HTML 解析(先不要看答...

    RobinQu 評(píng)論0 收藏0
  • 關(guān)于外部樣式也許你不知道的事

    摘要:如下圖所示,外部樣式表是否會(huì)阻塞解析先不要看答案,可以自己思考和實(shí)驗(yàn)一下通過如上圖所示,并沒有阻塞解析,因?yàn)闀r(shí)間線在之后。并且都支持事件回調(diào)處理,用于一些初始化工作。為了盡早地觸發(fā)事件,因?yàn)闀?huì)延遲事件觸發(fā)。 singsong: 文章中 demo 猛戳這里吧 ??最新內(nèi)容請(qǐng)以github上的為準(zhǔn)?? 在講解之前,先看一個(gè)問題。如下圖所示,外部樣式表是否會(huì)阻塞 HTML 解析(先不要看答...

    zhoutk 評(píng)論0 收藏0
  • CSS創(chuàng)始人之一Bert Bos:CSS只是進(jìn)化的一部分

    摘要:在的發(fā)展過程中,是最早與之父合作的人之一。問您認(rèn)為中國(guó)的開發(fā)者雖然起步晚,但是現(xiàn)在已經(jīng)趕上了是的。但是我知道,它們只是進(jìn)化的一部分。第一個(gè)最主要的原因就是要保護(hù)。 非商業(yè)轉(zhuǎn)載請(qǐng)注明作譯者、出處,并保留本文的原始鏈接:http://www.ituring.com.cn/article/194473 Bert Bos是一位計(jì)算機(jī)科學(xué)家,他也是CSS的創(chuàng)始人之一。在CSS的發(fā)展過程...

    tinyq 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<