引用JavaScript文件时的两个属性defer和async

引用js文件格式如下:

<script type="text/javascript" defer="defer" async="true/false" src="js文档地址"></script>
  • defer="defer":该属性用来通知浏览器,这段脚本代码将不会产生任何文档内容。例如JavaScript代码中的document.write()方法将不会骑作用,浏览器遇到这样的代码将会忽略,并继续执行后面的代码。属性只能是defer,与属性名相同。在HTML语法格式下,也允许不定义属性值,仅仅使用属性名。
  • async="true/false":该属性为html5中新增的属性,它的作用是能够异步地下载和执行脚本,不因为加载脚本而阻塞页面的加载。一旦下载完毕就会立刻执行。

async和defer一样,都不会阻塞其他资源下载,所以不会影响页面的加载,但在async的情况下,js文档一旦下载完毕就会立刻执行,所以很有可能不是按照原本的顺序来执行,如果js有依赖性,就要注意了。

如下图:

defer和async的比较

相同点:    

  • 加载文件时不阻塞页面渲染;
  • 对于inline的script无效;
  • 使用这两个属性的脚本中不能调用document.write方法;
  • 有脚本的onload的事件回调;
  • 允许不定义属性值,仅仅使用属性名;

 不同点:

  •  html的版本html4.0中定义了defer;html5.0中定义了async;这将造成由于浏览器版本的不同而对其支持的程度不同;
  •  执行时刻:每一个async属性的脚本都在它下载结束之后立刻执行,同时会在window的load事件之前执行。所以就有可能出现脚本执行顺序被打乱的情况;每一个defer属性的脚本都是在页面解析完毕之后,按照原本的顺序执行,同时会在document的DOMContentLoaded之前执行。

这两个属性会有三种可能的组合:

  • 如果async为true,那么脚本在下载完成后异步执行。
  • 如果async为false,defer为true,那么脚本会在页面解析完毕之后执行。
  • 如果async和defer都为false,那么脚本会在页面解析中,停止页面解析,立刻下载并且执行。

转载于:https://www.cnblogs.com/zhaiqianfeng/archive/2012/07/30/4616944.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
deferasync是用于控制脚本加载和执行机的属性。它们的主要区别在于执行机和脚本之间的依赖关系。 defer属性表示脚本的加载和执行是延迟的,即在HTML解析完毕后执行。它不会阻塞后续HTML的解析,但会按照脚本在HTML中的顺序执行。defer适用于需要保证脚本按照顺序执行的情况,因为它能够保证脚本之间的变量依赖关系。 async属性表示脚本的加载和执行是异步的,即在下载完成后立即执行。它也不会阻塞后续HTML的解析,但无法保证脚本的执行顺序,谁先下载完成谁先执行。因此,如果脚本之间存在依赖关系,不推荐使用async。 需要注意的是,asyncdefer都只适用于外联脚本,即通过src属性引入的脚本。它们不适用于内联脚本。 综上所述,通常情况下,defer的使用频率较高,它能够保证脚本之间的变量依赖关系。而async适用于独立的脚本,且不需要考虑脚本执行顺序的情况。 #### 引用[.reference_title] - *1* *3* [详解deferasync的原理及应用](https://blog.csdn.net/liuhe688/article/details/51247484)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [asyncdefer的区别?](https://blog.csdn.net/qq_44621394/article/details/126545273)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值