时间:2021-05-18
关于对延迟脚本的思考
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两种模式,区别在于:
相同点:
影响多个异步脚本的执行顺序因素
特殊情况
当所有的脚本文件都很小很小的时候,结果会在很大概率稳定在
使用的注意点
写在最后
到此这篇关于浅析我对JS延迟异步脚本的思考的文章就介绍到这了,更多相关JS 延迟异步脚本内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
Ajax:AsynchronousJavaScriptandXml,异步js脚本和xml,常用来实现页面局部的异步刷新,对提高用户体验有很大帮助.Xml在多语言
浅析javascript异步执行函数导致的变量变化问题解决思路for(vari=0;i
本文介绍了vue异步加载高德地图的实现,分享给大家,具体如下:几种加载js的方式同步加载异步加载延迟加载同步加载用的最多的一种方式,又称阻塞模式,会阻止浏览器的
Node.js中的事件触发器所引发的思考今天在看Node.js文档的时候讲到事件触发器,其中的emit方法让我想到了Vue中的自定义事件,借此我对Vue又有了新
一、问题本人在使用layui使用了select按钮,点击是js脚本会异步请求后台接口获取json数据,然后layui将json数据渲染到select上,然而获取