前端性能优化六:css阻塞

1. css加载会阻塞DOM树的解析和渲染吗?

(1). html代码:

html 复制代码
<!DOCTYPE html>
<html lang="en">
  <head>
    <style>
      h1 {
        color: red !important
      }
    </style>
    <script>
      function h () {
        console.log(document.querySelectorAll('h1'))
      }
      setTimeout(h, 0)
    </script>
    <link href="https://cdn.bootcss.com/bootstrap/4.0.0-alpha.6/css/bootstrap.css" rel="stylesheet">
  </head>
  <body>
    <h1>这是红色的</h1>
  </body>
</html>

(2). 打开一个新窗口,打开chrome的network,设置下载速度为slow 3G:

js 复制代码
①. html页面最开始就是Finished状态.

②. bootcss刚开始处于pending状态:
    a. 当css还没加载完成时,h1并没有显示.
    b. 但此时控制台输出内容.
    c. 直到css加载完成后,红色字体才显示出来.即:内容虽然解析了,但并没有被渲染出来.

③. 结论:
    a. DOM树至少已经解析完成到了h1那里.
    b. 此时css还没加载完成. => css并不会阻塞DOM树的解析.
    c. 加载完成后才显示. => css加载会阻塞DOM树渲染.

加载css时,可能会修改DOM节点的样式,如果css加载不阻塞DOM树渲染的话,那么当css加载完之后,DOM树可能又得重新重绘或者回流了,这就造成了一些没有必要的损耗。所以我干脆就先把DOM树的结构先解析完,把可以做的工作做完,然后等你css加载完之后,在根据最终的样式来渲染DOM树,这种做法性能方面确实会比较好一点。

2. css加载会阻塞js运行吗?

(1). html代码:

html 复制代码
<!DOCTYPE html>
<html lang="en">
  <head>
    <script>
      console.log('before css')
      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>这是红色的</h1>
    <script>
      var endDate = new Date()
      console.log('after css')
      console.log('经过了' + (endDate -startDate) + 'ms')
    </script>
  </body>
</html>

(2). 打开一个新窗口,打开chrome的network,设置下载速度为slow 3G:

js 复制代码
①. html页面最开始就是Finished状态.

②. bootcss刚开始处于pending状态:
    a. 当css还没加载完成时,h1并没有显示.
    b. 但此时控制台输出内容:before css. => css加载前的js代码先执行了.
    c. 直到css加载完成后,文字才显示出来. => css加载后的js代码没有执行.
    d. 此时,才显示after css、经过了5662ms.

③. 结论:
    a. css加载会阻塞后面的js语句的执行.
相关推荐
恋猫de小郭11 小时前
Flutter Zero 是什么?它的出现有什么意义?为什么你需要了解下?
android·前端·flutter
崔庆才丨静觅18 小时前
hCaptcha 验证码图像识别 API 对接教程
前端
passerby606119 小时前
完成前端时间处理的另一块版图
前端·github·web components
掘了19 小时前
「2025 年终总结」在所有失去的人中,我最怀念我自己
前端·后端·年终总结
崔庆才丨静觅19 小时前
实用免费的 Short URL 短链接 API 对接说明
前端
崔庆才丨静觅19 小时前
5分钟快速搭建 AI 平台并用它赚钱!
前端
崔庆才丨静觅20 小时前
比官方便宜一半以上!Midjourney API 申请及使用
前端
Moment20 小时前
富文本编辑器在 AI 时代为什么这么受欢迎
前端·javascript·后端
崔庆才丨静觅20 小时前
刷屏全网的“nano-banana”API接入指南!0.1元/张量产高清创意图,开发者必藏
前端
剪刀石头布啊20 小时前
jwt介绍
前端