共计 1879 个字符,预计需要花费 5 分钟才能阅读完成。
对于对提早脚本的思考
async
和defer
属性的脚本,置信大家都据说过,然而他的真正执行细节是什么样子的?很少有文章认真钻研它, 可能不太有人重视细节, 但其实真正有技术含量的工作和我的项目, 对于性能要求极高, 那么细节就很重要了. 须要一直的试验自我尝试- 最近几个月,我始终在钻研一些技术,例如
linux
, 操作系统, 算法等, 预计要继续学习到今年年底。红宝书第四版进去后,我也是花了很多工夫去看。对于提早脚本,本人也是做了一个试验,写下了这篇总结
什么是提早脚本?
script
标签,带async
和defer
属性等,通过document.createElement('script')
创立并且没有指定script.async=false
的脚本默认为异步提早
脚本(必须为非内联脚本), 如下所示:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
</head>
<body>
</body>
<script src="./async1.js" async></script>
<script src="./async2.js" async></script>
<script src="./defer1.js" defer></script>
<script src="./defer2.js" defer></script>
<script src="./common1.js"></script>
<script src="./common2.js"></script>
<script src="./common3.js"></script>
</html>
- 以上 7 个脚本文件, 其中
common
结尾为非异步提早脚本, 其余的都指定了提早脚本的模式,分为async
和defer
两种
通过 document.createElement 创立的标签插入默认为
async
模式
开始试验
- 我一共写了 2 个
async
和 2 个defer
标签, 其它的都是一般标签. 其中async1.js
外面有 4000 行代码, 其它都是一个console.log
而已 - 第一次试验后果:
- 再次刷新页面(留神我曾经禁用了浏览器缓存), 后果为:
- 再次刷新, 发现
async
执行机会和程序不确定,然而能确定defer
必定在async
之后执行。
起因在于:
async
是通知浏览器, 能够不用等到它下载解析完后再加载页面, 也不必等它执行完后再执行其余脚本, 俗称异步执行脚本
看下载执行机会和打印后果的比照
- 打印后果:
- 对应的下载执行机会
- 从下面看,下载机会
async
和一般模式都是同样并行下载, 只有 defer 是最初才下载 (http1.1 有并发数量限度
, 可是这里并不是并发限度,当我删除common
的援用后, 我发现defer
永远都是最初下载的)
-
async
和defer
两种模式,区别在于:async
是通知浏览器, 它不会操作dom
, 能够不用等到它下载解析完后再加载页面, 也不必等它执行完后再执行其余脚本, 俗称异步执行脚本
, 多个async
无奈保障他们的执行程序, 例如async1
和async2
无奈按程序执行defer
是在解析到完结到</html>
标签后才会执行, 俗称推延执行脚本
, 多个defer
能够按程序执行, 例如defer1
和defer2
能够按程序执行(实际上也不保障程序执行)- 解析到
script
标签后,async
是间接下载 - 解析到
script
标签后,defer
是最初下载
-
相同点:
- 多个
async
或者defer
标签实际上都不能保障程序执行 - 都不会阻塞解析其余
script
标签内容的解析和页面渲染 - 他们都会在浏览器
load
事件前执行,然而不保障是在DomContentLoad
事件前还是后执行 defer
必定在async
前面执行,从我的试验后果和书上对它们对解析来看
- 多个
影响多个异步脚本的执行程序因素
- 脚本文件大小
- 网络传输因素
非凡状况
- 当所有的脚本文件都很小很小的时候, 后果会在很大概率稳固在
应用的留神点
- 异步推延脚本的执行程序并不稳固, 所有尽量只有一个
- 应用异步推延脚本时, 应该思考什么场景才应用, 而不是滥用它
写在最初
- 纸上得来终觉浅, 欲知此事要躬行, 我写得也不肯定对, 如果你有问题或者更好的答案能够在上面参加探讨, 我始终认为有争议和拥护的声音是坏事
- 另外你如果感觉写得不错对你有帮忙, 能够帮忙点个
在看 / 赞 / 关注
. - 关注
前端巅峰
公众号后回复:加群
, 即可加群获取3800G
收费前端学习视频资源
正文完