async、defer 和 DOMContentLoaded 都涉及到HTML文档中脚本的加载和执行,但它们有不同的用途和行为。
async 属性:
当您在 <script> 标签中使用 async 属性时,脚本会异步加载,不会阻止页面的解析和渲染。
脚本会在加载完成后立即执行,而不管其在页面中的位置如何。这意味着脚本可能在页面的其他内容加载和解析之前运行。
如果有多个脚本使用 async 属性,并且它们之间有依赖关系,执行顺序可能会不确定。适合用于不需要按顺序执行的独立脚本。
示例:<script src="script1.js" async></script><script src="script2.js" async></script>
defer 属性:当您在 <script> 标签中使用 defer 属性时,脚本也会异步加载,但不会立即执行。
脚本会在页面解析完毕(DOM 树构建完成)之后,按照它们在页面中的顺序执行。
defer 保证了脚本按照它们在页面中的顺序执行,且在 DOMContentLoaded 事件之前完成执行。
适合用于需要按照顺序执行,但不需要阻止页面解析的脚本。示例:<script src="script1.js" defer></script>
<script src="script2.js" defer></script>
DOMContentLoaded 事件:DOMContentLoaded 是一个文档级事件,当整个HTML文档被解析和构建完毕后触发。
通常情况下,DOMContentLoaded 事件发生时,所有的DOM元素都已经可以操作了,但不一定包括外部资源如图片等的加载完成。
您可以使用这个事件来确保脚本在文档完全构建后执行,以防止脚本尝试操作尚未存在的DOM元素。
示例:document.addEventListener('DOMContentLoaded', function() {
// 在文档构建完毕后执行脚本});
总结:async 和 defer 用于控制脚本的加载和执行方式,而 DOMContentLoaded 是一个事件,用于在文档构建完毕后执行脚本。选择使用哪种取决于您的需求,是否需要按照顺序执行脚本以及是否需要等待整个文档构建完成。网友回复
如何编写一个chrome插件实现多线程高速下载大文件?
cdn版本的vue在网页中出现typeerror错误无法找到错误代码位置怎么办?
pywebview能否使用webrtc远程控制共享桌面和摄像头?
pywebview6.0如何让窗体接受拖拽文件获取真实的文件路径?
如何在linux系统中同时能安装运行apk的安卓应用?
python有没有离线验证码识别ocr库?
各家的ai图生视频及文生视频的api价格谁最便宜?
openai、gemini、qwen3-vl、Doubao-Seed-1.6在ui截图视觉定位这款哪家更强更准?
如何在linux上创建一个沙箱隔离的目录让python使用?
pywebview如何使用浏览器自带语音识别与webspeech 的api?