前端性能优化六: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语句的执行.
相关推荐
LaoZhangAI3 小时前
Google Gemini AI图片编辑完全指南:50+中英对照提示词与批量处理教程(2025年9月)
前端·后端
用户11481867894843 小时前
从零搭建 Vue3 + Nest.js 实时通信项目:4 种方案(短轮询 / 长轮询 / SSE/WebSocket)
前端·后端
LaoZhangAI3 小时前
Google Gemini Nano与Banana AI完整部署指南:2025年轻量级AI解决方案
前端·后端
Giant1003 小时前
0 基础也能懂的 Flex 布局教程:3 步搞定网页排版
css
用户11481867894844 小时前
基于 Webpack Module Federation 的 Vue 微前端实践
前端
怪可爱的地球人4 小时前
Pinia状态管理有哪些常用API?
前端
小高0074 小时前
🤔函数柯里化:化繁为简的艺术与实践
前端·javascript·面试
Sherry0074 小时前
【译】掌握 Flexbox 的终极指南:从烤肉串到鸡尾酒香肠的布局哲学
css·面试·flexbox
却尘4 小时前
React useMemo 依赖陷阱:组件重挂载,状态无限复原
前端·javascript·react.js
Asort4 小时前
JavaScript 从零开始(三):浏览器控制台与VS Code协同工作环境搭建详解
前端·javascript