参考

Youtube – #3 JavaScript Loading Strategies (async and defer) | JavaScript Full Tutorial

no async no defer

当游览器 parse HTML 遇到 <script src> 时, 它会去 download 这个 file, 这时会停止 parse HTML. 一直等到这个 JS file download 完毕.

然后游览器会开始 execute 这个 JS file 代码. executed 后继续 parse HTML.

parse HTML > download js > waiting download completed > execute js > continue parse HTML

async

async 是异步 download, 当游览器 download JS file 时, 它不会等, 而是继续 parse HTML.

等到这个 file download 完毕, 就暂停 parse HTML, 去 execute JS file. executed 后继续 parse HTML.

有一点需要特别注意, 如果有多个 async file, 游览器不会管它们的顺序, 哪个先 download 完毕就马上 execute.

parse HTML > download a.js (no waiting) > parse HTML > download b.js (no waiting) > parse HTML >

b.js finish download > execute b.js > parse HTML > a.js finish download > execute.a.js > parse HTML

defer

defer 也是异步 download, 但它 download 完毕之后并不会马上 execute. 而是等到 parse HTML 结束后才 execute.

而已它 execute 是讲究顺序的.

parse HTML > download a.js (no waiting) > parse HTML > download b.js (no waiting) > parse HTML >

b.js finish download (no run first) > parse HTML > a.js finish download (no run first) > parse HTML finish > execute.a.js (依据顺序) > execute b.js.

async defer together?

看到 facebook 的 sample code 是 2 给一起用. 于是查了一下

stackoverflow – Can you use both the async and defer attributes on a HTML script tag?

原来是为了兼容游览器, 有些游览器不支持 async. 注意是当你想 async 的时候但怕不支持所以才加上 defer. 而不是反过来哦.

async 如果运行的到, 那么 defer 就被无视了.

关于 DOMContentLoaded

参考: 详解 DOMContentLoaded

HTML parse 完以后, DomContentLoaded 会等到所有 defer download 完同时 execute 完以后才触发.

但是它不会去等待 async. HTML parse 完, 如果还有 async 没用在 download, 它不管, 会直接去触发 DomContentLoaded.

总结:

1. 以前需要把 JS 写到 body 最后面, 现在被 async defer 取代了.

2. async defer 用其中一个就可以了.

3. defer 是最常用的, 因为通常在乎顺序

4. async 的一个使用场景是 analytics 因为希望尽快做 tracking, defer 有点慢了.

Chrome Bug ? JS run before CSS render when using defer + compression

23-04-2022 遇到一个奇葩情况.

JavaScript 执行的比 CSS download file 还早. 这导致 computedStyle 获取到错误的值

它需要几个情况一起才会发生.

1. Chrome version 100.0.4896.127

2. script with defer

3. script with compression (br)

做了一个 ASP.NET Core 的测试环境

开启 compression, 当 download CSS 时刻意让它慢

HTML

Javascript 执行就 log

用 Firefox 测试效果是, 5 秒后 log

用 Chorme 是马上 log.

如果关闭 compression 效果则 Firefox 和 Chrome 都是 5 秒后 log.

如果把 defer 拿掉, 同时把 script 移动到 </body> 前, Firefox 和 Chrome 都是 5 秒后 log.

结论就是 Chrome + defer + compression 会导致 log 提前执行 (哪怕你放到 </body> 前).

所以建议暂时不要使用 defer, 改成把 script 放到 </body> 前.

HTML – script async defer的更多相关文章

  1. script async / defer

    script async / defer preload / prefetch https://abc.xgqfrms.xyz/ https://javascript.info/script-asyn ...

  2. [转]script之defer&async

    html5中script的async属性 我兴奋于html5的原因之一是一些久久未能实现的特性现在可以真正运用于实际项目中了. 如我们使用placeholder效果蛮久了但是那需要javascript ...

  3. 【HTML5 】<script>元素async,defer异步加载

    原文地址:HTML5′s async Script Attribute原文日期: 2010年09月22日翻译日期: 2013年08月22日 (译者注: 异步加载,可以理解为无阻塞并发处理.) (译者再 ...

  4. HTML5 <script>元素async,defer异步加载

    原文地址:HTML5′s async Script Attribute原文日期: 2010年09月22日翻译日期: 2013年08月22日 (译者注: 异步加载,可以理解为无阻塞并发处理.) (译者再 ...

  5. script的defer和async

    我们常用的script标签,有两个和性能.js文件下载执行相关的属性:defer和async defer的含义[摘自https://developer.mozilla.org/En/HTML/Elem ...

  6. <script>, <script async>, <script defer> 三种标签的区别

    <script>, <script async>, <script defer> 三种标签的区别 <script>标签 阻塞html parsing 脚 ...

  7. script async 和script defer的区别

    浏览器对js文件的操作主要有两部分:下载和执行: js文件下载在有些浏览器中是并行的,在有些浏览器中是串行的,如:IE8.firefox3.chrome2都是串行下载的: 执行在所有浏览器中默认是阻塞 ...

  8. HTML中<script>的defer属性与async属性

    defer 属性会在 DOMLoaded 事件之前完成异步加载,加载不会阻塞 DOM 解析,并且 script 的顺序会按照 DOM 中的顺序加载. async 属性就是异步加载,没有什么顺序的保证.

  9. <script> 的defer和async

    <script src="../file.js" async="async"></script> file.js---- 仅仅只有ale ...

  10. script async和defer

    1.没有async和defer,html解析时遇到script标签,会先去下载js文件,文件加载完成立即执行,执行完了再开始解析后面的html,是一个顺序流的过程 2.async,加载和渲染后续文档元 ...

随机推荐

  1. 基于Java网络书店商城设计实现(源码+lw+部署文档+讲解等)

    系统介绍: 随着科学技术的飞速发展,各行各业都在努力与现代先进技术接轨,通过科技手段提高自身的优势:对于网络书店商城当然也不能排除在外,随着网络技术的不断成熟,带动了网络书店商城,它彻底改变了过去传统 ...

  2. oeasy教您玩转vim - 11 - # 向前向后

    向前向后 回忆上节课内容 我们上次强化了起手势 回忆了基本的移动方式 hjkl 除 hjkl 外,据说还有更厉害的移动方式 是什么呢? 下素材 #这个素材,我们下载过,重温一下 wget github ...

  3. python selenium 判断元素是否存在,实现:找到元素,执行对应的代码;找不到元素,继续执行其他代码

    selenium因为找不到元素会抛出异常,导致执行结束 可以考虑使用driver.find_elements(),找不到元素时就会返回空列表,使用if-else语句,判断列表是否为空,非空,则正常找到 ...

  4. 关于SpringCloud Bus RemoteApplicationEvent 使用注意事项

    最近使用SpringCloud Bus 用于服务直接消息通信,遇到一些问题,记录下来给一样碰到问题的你一个解决方案 开发环境 : springboot 2.3.9.RELEASE spring-clo ...

  5. mysql索引失效的情况七字口诀:“模型数空运最快”

    mysql索引失效的情况 七字口诀:"模型数空运最快" 模:使用like进行模糊查询的时候,以百分号%开头的,索引就会失效. 型:代表数据类型,数据类型错误了,索引也会失效. 数: ...

  6. ffpyplayer源码编译报错:ffpyplayer/tools.pyx:182:28: Cannot assign type 'void (*)(void *, int, const char *, va_list) except * nogil' to 'void (*)(void *, int, const char *, va_list) noexcept nogil'

    编译ffpyplayer报错,具体错误如标题. 报错信息: ffpyplayer/tools.pyx:182:28: Cannot assign type 'void (*)(void *, int, ...

  7. PyTorch显存机制分析

    参考: ======================================================= 在pytorch中有几个关于显存的关键词: 在pytorch中显存为缓存和变量分 ...

  8. vim跳转到上次和下次光标位置

    在vim的命令模式下: ctrl + i    下次光标位置; ctrl + o   上次光标位置. =====================================

  9. 在vscode中通过修改launch.json文件为项目添加启动参数——在launch.json文件中修改args变量

    以前一直在使用pycharm,不管怎么说毕竟国内外的Python编程者大部分都更支持pycharm,并且认为pycharm是Python语言编程中最好用的编辑器,但是随着国内编程人员一茬一茬的兴起很多 ...

  10. 随时随地与 LLMs 聊天的开源项目「GitHub 热点速览」

    众所周知,本地运行 LLMs 需要下载模型(体积大),并且还比较吃硬件配置.近日 GitHub 推出了 GitHub Models 服务,让开发者可以在 GitHub 上免费测试 Llama.Phi ...