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

news/2025/1/31 21:49:29 标签: 前端, 性能优化, css, 开发语言, javascript, js, html

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

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


http://www.niftyadmin.cn/n/5838889.html

相关文章

OpenAI 宕机 | 如何让 k8s 集群更稳定

注&#xff1a;本文为 2024 年 12 月 “ OpenAI 宕机分析” 相关文章合辑。 未整理去重。 ChatGPT 的故障&#xff0c;官方这样解释… 明说 YYM 2024 年 12 月 14 日 18:50 广东 2024 12 11 (PST) OpenAI 经历了一次服务故障&#xff0c;OpenAI 给出了详细的解释和预防方案。…

Redis学习之哨兵一

一、基本概念 1.主从复制的问题&#xff1a; 一旦主节点出现故障需要手动的将一个从节点晋升为主节点同时需要修改应用方的主节点地址还需要通过命令其他节点去复制新的主节点。 主节点的写能力和存储能力受到单机的限制 2.高可用&#xff1a; 上图为一主二从的redis主从复制模…

C# OpenCV机器视觉:图像去雾

在一座常年被雾霾笼罩的城市里&#xff0c;生活着一位名叫阿强的摄影爱好者。阿强对摄影痴迷到骨子里&#xff0c;他总梦想着能捕捉到城市最真实、最美的瞬间&#xff0c;然后把这些美好装进他的镜头&#xff0c;分享给全世界。可这雾霾就像个甩不掉的大反派&#xff0c;总是在…

Spring Boot深度开发实践:从高效开发到生产级部署

一、Spring Boot核心机制深度解析 1.1 自动配置的魔法解密 条件化装配原理&#xff1a;深入ConditionalOnClass等注解的实现机制 自动配置加载流程&#xff1a;META-INF/spring.factories的加载过程与优先级控制 自定义自动配置策略&#xff1a;实现自定义Starter的完整生命…

设计模式 - 行为模式_Template Method Pattern模板方法模式在数据处理中的应用

文章目录 概述1. 核心思想2. 结构3. 示例代码4. 优点5. 缺点6. 适用场景7. 案例&#xff1a;模板方法模式在数据处理中的应用案例背景UML搭建抽象基类 - 数据处理的 “总指挥”子类定制 - 适配不同供应商供应商 A 的数据处理器供应商 B 的数据处理器 在业务代码中整合运用 8. 总…

arkts bridge使用示例

接上一篇&#xff1a;arkui-x跨平台与android java联合开发-CSDN博客 本篇讲前端arkui如何与后端其他平台进行数据交互&#xff0c;接上一篇&#xff0c;后端os平台为Android java。 arkui-x框架提供了一个独特的机制&#xff1a;bridge。 1、前端接口定义实现 定义一个bri…

[EAI-026] DeepSeek-VL2 技术报告解读

Paper Card 论文标题&#xff1a;DeepSeek-VL2: Mixture-of-Experts Vision-Language Models for Advanced Multimodal Understanding 论文作者&#xff1a;Zhiyu Wu, Xiaokang Chen, Zizheng Pan, Xingchao Liu, Wen Liu, Damai Dai, Huazuo Gao, Yiyang Ma, Chengyue Wu, Bin…

在Ubuntu下编译VLC

参考链接&#xff1a; https://blog.csdn.net/zyhse/article/details/113662686