理解 <script> 标签的 defer 和 async 属性

简介: 理解 <script> 标签的 defer 和 async 属性

defer和async都是用于控制浏览器下载和执行JavaScript的方式的属性。

defer属性的效果是将JavaScript文件的下载放在HTML文件下载完成之后,但在HTML页面的解析过程中,会优先执行JavaScript的下载和解析,但不会中断HTML的解析和渲染。也就是说,当HTML解析完成后,JavaScript文件才会运行,而不会阻塞DOM的解析和渲染。

async属性的效果是让JavaScript文件的下载和执行异步进行,也就是说,JavaScript文件的下载和执行不会阻塞HTML页面的解析和渲染,但这也会导致JavaScript文件的执行时间不可预测,因为它的下载和执行是在HTML页面渲染的同时进行的。在使用async的情况下,无法保证JavaScript文件的执行顺序,所以在涉及到依赖关系的JavaScript代码中使用async会带来问题。

以下是具体的代码例子:

使用defer属性:

<!DOCTYPE html>
<html>
 <head>
    <title>Defer Example</title>
    <script defer src="defer.js"></script>
 </head>
 <body>
    <h1>Hello World</h1>
 </body>
</html>

defer.js文件内容如下:

alert("defer script is executed.");

使用async属性:

<!DOCTYPE html>
<html>
 <head>
    <title>Async Example</title>
    <script async src="async.js"></script>
 </head>
 <body>
    <h1>Hello World</h1>
 </body>
</html>

async.js文件内容如下:

alert("async script is executed.");

需要注意的是,以上例子中的JavaScript文件都是简单的弹窗提示,实际应用中可能会涉及到更加复杂的操作。同时,以上例子中的defer和async属性都是在单个JavaScript文件的情况下使用的,如果在一个页面中有多个JavaScript文件,不同的文件使用不同的属性会带来不可预测的效果。因此,在使用defer和async属性时,需要根据具体情况进行慎重选择。

相关文章
|
6天前
|
JavaScript 前端开发 Go
理解 <script> 标签的 defer 和 async 属性
理解 <script> 标签的 defer 和 async 属性
23 3
|
6天前
|
JavaScript 前端开发 开发者
7个Js async/await高级用法
7个Js async/await高级用法
|
6天前
|
JSON JavaScript 前端开发
js中async的作用
js中async的作用
44 0
|
9月前
|
移动开发 Go UED
<script> 标签上的 defer 和 async 属性是什么?
它会执行以下步骤 1.暂停 HTML 文档解析器 2.创建新请求以下载脚本 3.在脚本完全下载后立即执行脚本 4.执行结束后,继续解析 HTML 文档
|
10月前
|
JavaScript
jQuery中(function(){})()执行顺序导致的不正常显示存在的几个问题
jQuery中(function(){})()执行顺序导致的不正常显示存在的几个问题
48 0
|
10月前
|
前端开发 JavaScript Go
script标签中async和defer的作用和区别?简述css盒模型?什么是闭包?
浏览器遇到script标签没有async和defer属性时,页面将会暂停解析来下载并执行script脚本,执行完毕继续解析页面(这样会阻塞页面,所以建议把script标签放在html底部)。
script标签中async和defer的作用和区别?简述css盒模型?什么是闭包?
|
Go API
script标签中defer和async有什么不同?
script标签中defer和async有什么不同?
87 0
script标签中defer和async有什么不同?
|
前端开发 JavaScript
JS循环中使用async、await的正确姿势
使用filter过滤item为vue或者react的选项
228 0
JS循环中使用async、await的正确姿势