游乐游手机版
首页/前端开发/文章详情

HTML defer延迟加载脚本的详细方法与实现教程

时间:2026-05-10 13:24
defer属性用于延迟外部脚本执行,直到HTML文档解析完成,此时DOM已就绪。它仅对带src属性的脚本有效,内联脚本会被忽略。多个defer脚本按HTML顺序执行,但需注意依赖关系,避免因顺序错误导致变量未定义。此外,defer不等待样式或图片加载,也不处理脚本加载失败或执行错误,需自行捕获异常。

说到脚本加载优化,defer属性几乎是前端工程师的必修课。但你真的了解它的全部规则吗?它并非一个“加了就万事大吉”的魔法开关,其行为背后有一套精确的浏览器规范。今天,我们就来彻底搞懂defer,避开那些看似不起眼、实则影响深远的“坑”。

HTML怎么做defer加载_html script defer延迟加载方法【一文搞懂】

首先明确一点:defer的核心作用是延迟脚本执行,直到浏览器完成整个HTML文档的解析。这意味着,在defer脚本执行时,DOM树已经构建完毕,你可以安全地操作document.body或通过document.getElementById获取元素。但请注意,它不会等待样式表、图片或其他子资源加载完成,这个时机在DOMContentLoaded事件之前。

defer 只对外部脚本(src)有效

这是一个关键限制。defer属性只对带有src属性的外部脚本文件生效。对于内联脚本,浏览器会直接忽略defer属性,既不报错,也不会延迟执行。

  • 错误示例 —— 这里的init()函数会在HTML解析器遇到该标签时立即执行,与不加defer时行为完全一致。
  • 正确用法 —— 脚本的下载过程是异步的,不会阻塞HTML解析,而其执行则被推迟到DOM就绪之后。
  • 注意细节defer是一个布尔属性,即使你写成defer="false",它依然会生效。最佳实践是只写属性名而不赋值。

多个 defer 脚本按 HTML 顺序执行,但依赖链必须写对

另一个重要特性是执行顺序的保证。所有带defer属性的脚本,会按照它们在HTML文档中间出现的顺序依次执行。但这“保序”指的是执行顺序,而非加载完成顺序。浏览器会并行下载这些脚本,谁先下载完并不影响最终的执行序列。

然而,这带来了一个常见的逻辑陷阱:执行顺序保序不等于依赖关系自动满足。如果你的app.js依赖于lodash.js提供的_变量,但HTML中app.js的标签却写在lodash.js前面,那么执行app.js时就会抛出ReferenceError: _ is not defined的错误。

  • 正确顺序
  • 错误顺序
  • 混用警告:如果在同一个,如果该文件内包含document.write('

    ...

    ')
    ,很可能导致页面渲染异常。
  • 替代方案:应使用document.body.insertAdjacentHTMLdocument.createElement配合appendChild等DOM操作方法来实现动态内容插入。
  • 数据注入注意:对于服务端渲染时注入的全局初始化数据(例如window.__INITIAL_STATE__),其脚本标签必须放在所有defer脚本之前,并且自身不能添加defer属性。否则,后续的defer脚本在执行时将无法读取到这些数据。

最后,一个容易被忽略的核心事实是:defer只管理脚本的执行时机,并不对脚本的执行结果负责。如果脚本文件因404路径找不到、被内容安全策略(CSP)拦截、或者脚本内部的动态import()失败,defer机制并不会拦截或重试这些错误。这些运行时问题,必须依靠代码内部的错误捕获和降级逻辑来妥善处理。

来源:https://www.php.cn/faq/2450153.html
上一篇Bootstrap双栏等高布局实现方法 align-items-stretch属性应用详解 下一篇JavaScript严格模式下使用Objectseal方法防止动态属性注入攻击指南
本站内容用于信息整理与展示,如有侵权或内容问题请及时联系处理。

相关推荐

补充同频道和同主题内容,方便继续浏览更多相关内容。

同类最新

继续查看同栏目最近更新的文章。

更多
如何在JavaScript中实现基于旋转视野的FOV射线绘制详解
前端开发 · 2026-07-01

如何在JavaScript中实现基于旋转视野的FOV射线绘制详解

如果用一句话概括核心,那就是:在 RayCasting 游戏开发中,绘制动态视野边界线(FOV)最可靠的方式是在逻辑层通过数学公式将坐标“算”出来,而不是依赖 Canvas 绘图上下文的旋转操作。 在实现类似 Doom 风格的 RayCasting 游戏时,动态视野(Field of View, F

TypeScript后端数据正确映射为前端接口类型的方法
前端开发 · 2026-07-01

TypeScript后端数据正确映射为前端接口类型的方法

在后端数据与前端类型之间来回转换,几乎是每位 TypeScript 开发者都无法回避的常态。后端返回的 car_brand、reg_number,和前端接口中定义的 brand、govtNumber,命名风格常常对不上号。此时,如果为了省事直接用 as 类型断言“强行”指认类型,那就踩进了常见的陷阱

动态HTML表格按层级条件合并单元格的JavaScript实现
前端开发 · 2026-07-01

动态HTML表格按层级条件合并单元格的JavaScript实现

本文详细讲解一种递归式 JavaScript 合并单元格方法,用于按列优先级(如前3列)智能合并表格行:仅当前一列已合并的前提下,才允许后续列合并相同值,从而精准实现多级分组与层级表格合并效果。 在动态生成的 HTML 表格中,按业务逻辑合并重复行是常见需求。然而,简单地对单列分别遍历合并——例如先

Next.js 13+重定向后滚动失效解决方案
前端开发 · 2026-07-01

Next.js 13+重定向后滚动失效解决方案

在 Next js App Router 的日常开发中,有一个令人颇为困扰的异常现象——当服务端执行 `redirect()` 跳转后,目标页面竟然无法正常滚动。没错,页面已经渲染完成,内容也完整显示,但垂直滚动条仿佛凭空消失。这个问题在 Next js 13 5 4 版本中尤为突出。 先给出结论:

WebGL图像加载延迟的纹理初始化时立即显示方法
前端开发 · 2026-07-01

WebGL图像加载延迟的纹理初始化时立即显示方法

本文详细介绍如何利用 Promise 与 async await 重构 WebGL 纹理加载流程,彻底解决首次渲染显示蓝色占位色、需要手动交互才能刷新的问题,实现文件导入后四张纹理平面即时正确渲染。 实际上,这个坑在 WebGL 开发中相当常见——纹理异步加载的小陷阱,说起来不大,但第一次遇到确实令