搜尋
首頁web前端css教學詳解css載入會造成阻塞嗎
詳解css載入會造成阻塞嗎Dec 05, 2017 pm 04:07 PM
css阻塞

js執行會阻塞DOM樹的解析和渲染,那麼css載入會阻塞DOM樹的解析和渲染嗎?所以,接下來我就來對css載入對DOM樹的解析和渲染做一個測試。

為了完成本次測試,先來科普一下,如何利用chrome來設定下載速度

1、開啟chrome控制台(按下F12),可以看到下圖,重點在我畫紅圈的地方

2、點擊我畫紅圈的地方(No throttling),會看到下圖,我們選擇GPRS這個選項

3、這樣,我們對資源的下載速度上限就會被限製成20kb/s,好,那接下來就進入我們的正題

css載入會阻塞DOM樹的解析渲染嗎?

用程式碼說話:


<!DOCTYPE html>
<html lang="en">
  <head>
    <title>css阻塞</title>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1">
    <style>
      h1 {
        color: red !important
      }
    </style>
    <script>
      function h () {
        console.log(document.querySelectorAll(&#39;h1&#39;))
      }
      setTimeout(h, 0)
    </script>
    <link href="https://cdn.bootcss.com/bootstrap/4.0.0-alpha.6/css/bootstrap.css" rel="stylesheet">
  </head>
  <body>
    <h1 id="这是红色的">这是红色的</h1>
  </body>
</html>


假設: css載入會阻塞DOM樹解析和渲染

假設結果: 在bootstrap.css還沒載入完之前,下面的內容不會被解析渲染,那麼我們一開始看到的應該是白屏,h1不會顯示出來。而此時console.log的結果應該是一個空數組。

實際結果:如下圖

css會阻塞DOM樹解析?

由上圖我們可以看到,當css還沒載入完成的時候,h1並沒有顯示,但是此時控制台輸出如下

#可以得知,此時DOM樹至少已經解析完成到了h1那裡,而此時css還沒載入完成,也就說明,css並不會阻塞DOM樹的解析。

css載入會阻塞DOM樹渲染?

由上圖,我們也可以看到,當css還沒載入出來的時候,頁面顯示白屏,直到css載入完成之後,紅色字體才顯示出來,也就是說,下面的內容雖然解析了,但並沒有被渲染出來。所以,css載入會阻塞DOM樹渲染。

個人對此機制的評價

其實我覺得,這可能也是瀏覽器的最佳化機制。因為你載入css的時候,可能會修改下面DOM節點的樣式,如果css載入不阻塞DOM樹渲染的話,那麼當css載入完之後,DOM樹可能又得重新重繪或者回流了,這就造成了一些沒有必要的損耗。所以我乾脆就先把DOM樹的結構先解析完,把可以做的工作做完,然後等你css加載完之後,在根據最終的樣式來渲染DOM樹,這種做法性能方面確實會比較好一點。

css載入會阻塞js運行嗎?

由上面的推論,我們可以得到,css載入不會阻塞DOM樹解析,但會阻塞DOM樹渲染。那麼,css載入會不會阻塞js執行呢?

同樣,透過程式碼來驗證.


#
<!DOCTYPE html>
<html lang="en">
  <head>
    <title>css阻塞</title>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1">
    <script>
      console.log(&#39;before css&#39;)
      var startDate = new Date()
    </script>
    <link href="https://cdn.bootcss.com/bootstrap/4.0.0-alpha.6/css/bootstrap.css" rel="stylesheet">
  </head>
  <body>
    <h1 id="这是红色的">这是红色的</h1>
    <script>
      var endDate = new Date()
      console.log(&#39;after css&#39;)
      console.log(&#39;经过了&#39; + (endDate -startDate) + &#39;ms&#39;)
    </script>
  </body>
</html>


##假設: css載入會阻塞後面的js運行

預期結果: 在link後面的js程式碼,應該要在css載入完成後才會執行

實際結果:


由上圖我們可以看出,位於css載入語句前的那個js程式碼先執行了,但是位於css載入語句後面的程式碼遲遲沒有執行,直到css載入完成後,它才執行。這也就說明了,css載入會阻塞後面的js語句的執行。詳細結果看下圖(css載入用了5600+ms):

#結論##由上所述,我們可以得出以下結論:

1.css載入不會阻塞DOM樹的解析

2.css載入會阻塞DOM樹的渲染

3.css載入會阻塞後面js語句的執行

因此,為了避免讓使用者看到長時間的白螢幕時間,我們應該盡可能的提高css載入速度,例如可以使用以下幾種方法:

1.使用CDN(因為CDN會根據你的網路狀況,替你挑選最近的一個具有快取內容的節點為你提供資源,因此可以減少載入時間)
2.對css進行壓縮(可以使用很多打包工具,例如webpack,gulp等,也可以透過開啟gzip壓縮)
3.合理的使用快取(設定cache-control,expires,以及E-tag都是不錯的,不過要注意一個問題,就是檔案更新後,你要避免快取而帶來的影響。寫成內聯樣式(內聯樣式的一個缺點就是不能快取)

以上內容就是css載入會造成阻塞的詳解,希望對大家有幫助。

相關建議:

CSS中hover選擇器的使用詳解

#為什麼有時候DIV CSS載入失敗

#判斷在css載入完畢後執行後續程式碼範例_javascript技巧

以上是詳解css載入會造成阻塞嗎的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
利用CSS怎么创建渐变色边框?5种方法分享利用CSS怎么创建渐变色边框?5种方法分享Oct 13, 2021 am 10:19 AM

利用CSS怎么创建渐变色边框?下面本篇文章给大家分享CSS实现渐变色边框的5种方法,希望对大家有所帮助!

css ul标签怎么去掉圆点css ul标签怎么去掉圆点Apr 25, 2022 pm 05:55 PM

在css中,可用list-style-type属性来去掉ul的圆点标记,语法为“ul{list-style-type:none}”;list-style-type属性可设置列表项标记的类型,当值为“none”可不定义标记,也可去除已有标记。

css与xml的区别是什么css与xml的区别是什么Apr 24, 2022 am 11:21 AM

区别是:css是层叠样式表单,是将样式信息与网页内容分离的一种标记语言,主要用来设计网页的样式,还可以对网页各元素进行格式化;xml是可扩展标记语言,是一种数据存储语言,用于使用简单的标记描述数据,将文档分成许多部件并对这些部件加以标识。

css3怎么实现鼠标隐藏效果css3怎么实现鼠标隐藏效果Apr 27, 2022 pm 05:20 PM

在css中,可以利用cursor属性实现鼠标隐藏效果,该属性用于定义鼠标指针放在一个元素边界范围内时所用的光标形状,当属性值设置为none时,就可以实现鼠标隐藏效果,语法为“元素{cursor:none}”。

css怎么实现英文小写转为大写css怎么实现英文小写转为大写Apr 25, 2022 pm 06:35 PM

转换方法:1、给英文元素添加“text-transform: uppercase;”样式,可将所有的英文字母都变成大写;2、给英文元素添加“text-transform:capitalize;”样式,可将英文文本中每个单词的首字母变为大写。

rtl在css是什么意思rtl在css是什么意思Apr 24, 2022 am 11:07 AM

在css中,rtl是“right-to-left”的缩写,是从右往左的意思,指的是内联内容从右往左依次排布,是direction属性的一个属性值;该属性规定了文本的方向和书写方向,语法为“元素{direction:rtl}”。

css怎么设置i不是斜体css怎么设置i不是斜体Apr 20, 2022 am 10:36 AM

在css中,可以利用“font-style”属性设置i元素不是斜体样式,该属性用于指定文本的字体样式,当属性值设置为“normal”时,会显示元素的标准字体样式,语法为“i元素{font-style:normal}”。

怎么设置rotate在css3的旋转中心点怎么设置rotate在css3的旋转中心点Apr 24, 2022 am 10:50 AM

在css3中,可以用“transform-origin”属性设置rotate的旋转中心点,该属性可更改转换元素的位置,第一个参数设置x轴的旋转位置,第二个参数设置y轴旋转位置,语法为“transform-origin:x轴位置 y轴位置”。

See all articles

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
2 週前By尊渡假赌尊渡假赌尊渡假赌
倉庫:如何復興隊友
1 個月前By尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒險:如何獲得巨型種子
4 週前By尊渡假赌尊渡假赌尊渡假赌

熱工具

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

EditPlus 中文破解版

EditPlus 中文破解版

體積小,語法高亮,不支援程式碼提示功能

SublimeText3 英文版

SublimeText3 英文版

推薦:為Win版本,支援程式碼提示!

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

強大的PHP整合開發環境