script标签中的defer和async使用技巧说明

 更新时间:2023年02月18日 14:34:33   作者:藏锋de刃  
这篇文章主要介绍了script标签中的defer和async使用技巧,包含他们的下载顺序和执行顺序,以及使用场景需要的朋友可以参考下

script标签用于加载脚本与执行脚本,在前端开发中可以说是非常重要的标签了。
直接使用script脚本的话,html会按照顺序来加载并执行脚本,在脚本加载&执行的过程中,会阻塞后续的DOM渲染。

image

普通script:

  • 文档解析的过程中,如果遇到script脚本,停止页面的解析渲染,下载script脚本。
  • 如果是多个script脚本, 近似于同时并行下载script脚本。(虽然说是遇到script脚本, 就停止后面标签的解析渲染; 但chrome做了优化, 遇到script脚本, 会快速的查看后边有没有需要下载其他资源的, 一起并行下载, 为了节省一部分下载的时间。)
  • 不论script脚本哪个先下载好, 都按照html中的先后顺序依此执行。 即如果后面的script脚本先下载好, 要等前面的script脚本下载好并执行后, 才能执行。
  • 执行script脚本时, 也是停止页面的解析渲染。
  • 执行完script脚本, 继续页面的解析渲染。
  • 执行完script脚本和页面解析渲染完, 才会依此触发DOMContentLoaded, loaded事件

image

普通script总结:

  • 1.普通script的下载和执行都阻塞页面的解析渲染。
  • 2. 多个script的下载是并行, 但按照页面中顺序依此执行。
  • 3. 考虑到不支持defer和async的老浏览器, 最佳实践是script放在body底部, 避免阻塞页面的解析渲染。
  • 4.执行完script脚本, 继续页面的解析渲染。页面解析渲染完, 才会触发DOMContentLoaded。所以普通script脚本的下载和执行如果慢, 会延迟DOMContentLoaded事件的触发时间。

image

defer:

  • 文档解析时,遇到设置了defer的script脚本,就会在后台进行下载,下载并不会阻止文档的解析渲染。
  • 如果是多个设置了defer的script脚本, 近似于同时并行下载defer脚本。
  • 当页面解析渲染完毕后,会等到所有的defer脚本下载完毕并按照顺序执行,执行完毕后会触发DOMContentLoaded事件。
  • 如果defer脚本下载较快, 会等到页面解析渲染完毕后, 才按照顺序执行defer脚本。执行完毕后会触发DOMContentLoaded事件。
  • 如果defer脚本下载较慢, 在下载完前,页面解析渲染已完毕; 等defer脚本下载完后,才按照顺序执行defer脚本。执行完毕后会触发DOMContentLoaded事件。

defer 总结:

  • 1.defer脚本的下载和执行都不会阻塞页面的解析渲染。因为等到页面的解析渲染完毕后,defer脚本才执行, 所以defer脚本执行也不会阻塞页面的解析渲染。
  • 2. 多个defer脚本的下载是并行, 但按照顺序依此执行。
  • 3. 等页面的解析渲染完毕后,触发DOMContentLoaded事件前,defer脚本才依次执行。 所以defer脚本的下载和执行如果慢, 会延迟DOMContentLoaded事件的触发时间。
  • 4. 考虑有的浏览器不支持 defer场景, 多个defer脚本不一定会按照顺序执行, 最佳实践是只使用一个defer脚本。

defer推荐使用场景:

如果你的脚本代码依赖于页面中的DOM元素(文档是否解析完毕),或者被其他脚本文件依赖。

例:

  • 1. 评论框
  • 2.代码语法高亮
  • 3.polyfill.js

image

async:

  • 文档解析时,遇到设置了async的script脚本,就会在后台进行下载,下载并不会阻止文档的解析渲染。
  • 如果是多个设置了async的script脚本, 近似于同时并行下载async脚本。
  • async脚本的执行会阻止文档的解析渲染。
  • 哪个async脚本先下载完, 就立刻执行,执行时阻止文档的解析渲染。async脚本执行顺序不按照页面中的脚本先后顺序。
  • async脚本的下载和执行不计入DOMContentLoaded事件统计。
  • 因async脚本下载不阻塞文档的解析渲染;如果async脚本下载较快, 趁async脚本下载很短时间内, 文档的解析渲染未完成, async下载后立即执行,执行时会阻塞文档的解析渲染; 执行后, 继续文档的解析渲染, 等页面的解析渲染完毕后,触发DOMContentLoaded事件。这种场景, async脚本的执行如果慢, 会延迟DOMContentLoaded事件的触发时间。
  • 如果async脚本下载较慢, 当async还在下载时, 文档的解析渲染已完成,这时不会等待async的下载, 会直接触发DOMContentLoaded事件。这种场景, async脚本的下载和执行不会延迟DOMContentLoaded事件的触发时间。

async总结:

  • 1.async脚本的下载不会阻塞页面的解析渲染。async脚本的执行会阻塞页面的解析渲染。
  • 2. 多个async脚本的下载是并行, 但执行不按照页面中的脚本先后顺序。哪个async脚本先下载完, 哪个async脚本就先立刻执行。
  • 3.async脚本的下载和执行不计入DOMContentLoaded事件统计。
  • 4. async脚本的执行有可能在DOMContentLoaded事件前, 也有可能在DOMContentLoaded事件后。
  • 5. 当async脚本的执行在DOMContentLoaded事件前时,async脚本的执行时间才会影响DOMContentLoaded事件的触发时间。又因为脚本的执行时间一般都比较短, 所以可以认为async脚本基本不影响DOMContentLoaded事件的触发时间。

async推荐使用场景:

如果你的脚本并不关心页面中的DOM元素(文档是否解析完毕),并且也不会产生其他脚本需要的数据。

例:

1. 百度统计和Google Analytics

image

image

普通script, defer, async同时存在页面中:

  • 1. 普通script执行完, 继续页面解析渲染;页面解析渲染完, 才触发DOMContentLoaded事件。
  • 2.defer脚本是在页面解析渲染完,DOMContentLoaded事件的触发前, 才执行defer脚本。
  • 3. 由于1,2这两点, 所以一定先执行普通script, 再执行defer脚本。
  • 4.async脚本的下载和执行不计入DOMContentLoaded事件统计。
  • 5.async脚本下载完, 就立刻执行, 且多个async脚本执行不按照页面中的脚本先后顺序。

由于4,5这两点, 所以async脚本执行与普通script, defer脚本无关, 那个时间点都有可能执行。

注意:defer,async只对外联script脚本文件有效, 内联script脚本设置无效。

以上就是script标签中的defer和async的详细内容,更多关于script标签中的defer和async的资料请关注脚本之家其它相关文章!

相关文章

  • ES6新特性六:promise对象实例详解

    ES6新特性六:promise对象实例详解

    这篇文章主要介绍了ES6新特性之promise对象,结合实例形式详细分析了promise对象的功能、状态、使用方法与相关操作技巧,需要的朋友可以参考下
    2017-04-04
  • js实现不提交表单获取单选按钮值的方法

    js实现不提交表单获取单选按钮值的方法

    这篇文章主要介绍了js实现不提交表单获取单选按钮值的方法,涉及javascript鼠标事件及页面元素属性操作的相关技巧,具有一定参考借鉴价值,需要的朋友可以参考下
    2015-08-08
  • Web开发必知Javascript技巧大全

    Web开发必知Javascript技巧大全

     JavaScript是一个绝冠全球的编程语言,可用于Web开发、移动应用开发(PhoneGap、Appcelerator)、服务器端开发(Node.js和Wakanda)等等,通过本文给大家介绍Web开发必知Javascript技巧大全,需要的朋友参考下吧
    2016-02-02
  • js实现宇宙星空背景效果的方法

    js实现宇宙星空背景效果的方法

    这篇文章主要介绍了js实现宇宙星空背景效果的方法,实例分析了javascript中动画效果的实现技巧,具有一定参考借鉴价值,需要的朋友可以参考下
    2015-03-03
  • JS仿百度搜索自动提示框匹配查询功能

    JS仿百度搜索自动提示框匹配查询功能

    这篇文章主要介绍了JS输入框模糊匹配查询功能,主要是仿百度搜索自动提示框的功能,大家参考使用吧
    2013-11-11
  • bootstrap模态框消失问题的解决方法

    bootstrap模态框消失问题的解决方法

    这篇文章主要为大家详细整理了bootstrap模态框消失不消失各种问题的解决方法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2016-12-12
  • 十分钟教你上手ES2020新特性

    十分钟教你上手ES2020新特性

    这篇文章主要介绍了十分钟教你上手ES2020新特性,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-02-02
  • javascript实现抢购倒计时程序

    javascript实现抢购倒计时程序

    这篇文章主要为大家详细介绍了javascript实现抢购倒计时程序,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-08-08
  • javascript仿XP关机效果的弹出窗口功能

    javascript仿XP关机效果的弹出窗口功能

    javascript仿XP关机效果的弹出窗口功能...
    2007-10-10
  • javascript+ajax实现产品页面加载信息

    javascript+ajax实现产品页面加载信息

    本文给大家分享的是使用javascript结合ajax实现产品页面无刷新加载信息的代码,非常的简单实用,有需要的小伙伴可以参考下。
    2015-07-07

最新评论