前端性能优化指标 - DCL(触发时机、脚本对 DCL 的影响、CSS 对 DCL 的影响)

前端性能优化指标 DCL

1、概述
  • DCL(DOMContentLoaded)表示浏览器已经完全加载并解析了页面的初始 HTML 文档,同时完成了 DOM 树的构建,但需等待样式表、图片等外部资源的加载
2、触发时机
  1. 当 HTML 文档被完全加载和解析时触发

  2. 此时,DOM 树已经构建完成,但外部资源(例如,样式表、图片、脚本等)可能仍在加载中

  3. 如果页面中有同步的 JavaScript 脚本(未使用 async 或 defer 属性),浏览器会等待这些脚本执行完毕后再触发 DCL

3、影响 DCL 的因素
(1)基本介绍
  1. HTML 文档大小:HTML 文件越大,解析时间越长,DCL 时间越晚

  2. 同步 JavaScript 脚本:同步脚本会阻塞 DOM 解析,延迟 DCL 的触发

  3. 网络延迟:HTML 文件加载时间受网络速度影响,网络越慢,DCL 时间越长

  4. CSS 文件加载:虽然 CSS 不会阻塞 DOM 解析,但会阻塞页面渲染,间接影响 DCL

(2)优化策略
  1. 减少 HTML 文件大小:压缩 HTML 文件,移除不必要的空格、注释和冗余代码

  2. 异步加载 JavaScript:使用 async 或 defer 属性加载脚本,避免阻塞 DOM 解析

  3. 优化网络请求:使用 CDN 加速 HTML 文件的加载,减少网络延迟

  4. 内联关键 CSS:将关键 CSS 直接内联到 HTML 中,减少外部 CSS 文件的阻塞时间


学习补充

1、脚本对 DCL 的影响
  1. 同步脚本:会阻塞 HTML 解析,DCL 需要等待脚本执行完成

  2. 异步脚本(async):不会阻塞 HTML 解析,DCL 不需要等待脚本

  3. 延迟脚本(defer):不会阻塞 HTML 解析,但 DCL 需要等待脚本执行完成

2、脚本分类
  • 在前端开发中,script 标签用于加载和执行 JavaScript 代码,根据加载和执行方式的不同,script 标签可以分为同步脚本、异步脚本(async)和延迟脚本(defer)
  1. 同步脚本:当浏览器解析到 script 标签时,会立即停止 HTML 文档的解析,加载并执行脚本文件,脚本执行完毕后才会继续解析HTML文档
  • 特点:阻塞HTML解析多个脚本顺序执行
html 复制代码
<script src="script1.js"></script>
<script src="script2.js"></script>
  1. 异步脚本(async):使用 async 属性的脚本会在下载完成后立即执行,执行时会阻塞 HTML 解析,异步脚本的下载与 HTML 解析并行进行,但执行时会暂停 HTML 解析
  • 特点:并行加载多个脚本执行顺序不确定
html 复制代码
<script async src="script1.js"></script>
<script async src="script2.js"></script>
  1. 延迟脚本(defer):使用 defer 属性的脚本会在HTML文档解析完成后,按照它们在文档中出现的顺序依次执行
  • 特点:并行加载多个脚本顺序执行
html 复制代码
<script defer src="script1.js"></script>
<script defer src="script2.js"></script>
3、CSS 对 DCL 的影响
  1. CSS 不会直接阻塞 DOM 解析,但它可能会间接影响 JavaScript 执行,从而对 DCL 的触发时间产生一定的影响

  2. 例如,如果页面中存在依赖于 CSSOM 的 JavaScript 代码(例如,通过 document.styleSheets 访问样式表),浏览器会等待 CSS 文件加载完成后再执行这些脚本,如果这些脚本是同步加载的,会延迟 DCL 的触发

相关推荐
jk_10121 分钟前
MATLAB中extractAfter函数用法
开发语言·matlab
笑口常开xpr29 分钟前
C语言 --- 循环(1)
c语言·开发语言
不做超级小白1 小时前
小白爬虫冒险之反“反爬”:无限debugger、禁用开发者工具、干扰控制台...(持续更新)
javascript·python
浪遏1 小时前
NestJs👈 | 前端spring🤔| 项目创建与项目结构解析
前端·javascript·后端
magic 2451 小时前
Java继承中的静态方法隐藏与实例变量隐藏:深入解析与最佳实践
java·开发语言·javase
maizeman1262 小时前
R语言统计分析——ggplot2绘图4——刻面
开发语言·r语言·可视化·ggplot·刻面
轻口味2 小时前
Vue.js 什么是 Vuex?
前端·javascript·vue.js
LCG元3 小时前
Vue.js组件开发-实现全屏平滑移动、自适应图片全屏滑动切换
前端·javascript·vue.js
DARLING Zero two♡3 小时前
C++传送锚点的内存寻址:内存管理
开发语言·c++·内存管理