最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

JavaScript异步加载的详细介绍(附代码)

来源:动视网 责编:小采 时间:2020-11-27 19:26:43
文档

JavaScript异步加载的详细介绍(附代码)

JavaScript异步加载的详细介绍(附代码):本篇文章给大家带来的内容是关于JavaScript异步加载的详细介绍(附代码),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。讲这个问题之前, 我们从另一个面试高频问题来切入,我们的web页面从开始解析到页面渲染完成都经历了什么 ? 1、
推荐度:
导读JavaScript异步加载的详细介绍(附代码):本篇文章给大家带来的内容是关于JavaScript异步加载的详细介绍(附代码),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。讲这个问题之前, 我们从另一个面试高频问题来切入,我们的web页面从开始解析到页面渲染完成都经历了什么 ? 1、
 本篇文章给大家带来的内容是关于JavaScript异步加载的详细介绍(附代码),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。

讲这个问题之前, 我们从另一个面试高频问题来切入,

我们的web页面从开始解析到页面渲染完成都经历了什么 ?

1、创建document对象, 开始解析页面, 此时document.readyState = 'loading'

2、遇到link标签引入的css文件, 创建线程并异步加载css,继续解析文档

3、遇到script标签引入的外部脚本 , 如果script标签的属性设置了defer或者async 则 创建线程异步加载js , 否则同步加载js(阻塞了dom的解析) , 继续解析文档 (async脚本加载完就执行)

4、遇到img等要加载资源的标签, 正常解析dom 标签 , 异步加载src , 继续解析文档

5、文档解析完毕 , document.readyState = 'interactive' , 所有defer脚本按顺序执行,并且document会触发 DOMContentLoaded事件 , 标志着程序从同步脚本执行阶段转化成事件驱动阶段

6、当所有async 脚本 加载并执行 完毕 , img 加载完毕 , document.readyState = 'complete' , window 触发 load 事件 。

7、从此 以异步响应的方式处理用户输入, 网络事件等 。。。

ok , 光说没用, 我们来看看是否只有一个。。

document.onreadystatechange = () => {
 console.log(document.readyState)
};
document.addEventListener('DOMContentLoaded', () => {
 console.log('DOMContentLoaded')
});
window.onload = () => {
 console.log('load')
};

注意一点, DOMContentLoaded 事件 只能用 addEventListener 来绑定

结果是这样:

按顺序打印出来了 。。

上文我们提到只有设置了defer /async 的 script 脚本 才能异步加载 ,

注意defer 有些低版本浏览器不兼容,

async是W3C的标准,但只能在引入外部js文件时使用,

当然,我们最常用的是把script标签放在body 后面 ,这样就不会阻塞dom解析

还有一种情况, 动态添加的script脚本也是异步加载的, 基于此 我们来封装一个 异步加载script脚本的函数

function loadScript (url, callback) { // 传入url , 和要执行的回调函数
 const script = document.createElement('script');
 script.type = 'text/javascript'; // 创建一个script标签
 if (script.readyState) { // 做兼容
 script.onreadystatechange = () => { // readyState变化触发
 if (script.readyState === 'complete' || script.readyState === 'loaded') { // 兼容
 callback(); // 加载完执行回调 }
 }
 } else {
 script.onload = () => {
 callback(); // 加载完执行回调 }
 }
 script.src = url;
 document.head.appendChild(script); // 插入head中}

文档

JavaScript异步加载的详细介绍(附代码)

JavaScript异步加载的详细介绍(附代码):本篇文章给大家带来的内容是关于JavaScript异步加载的详细介绍(附代码),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。讲这个问题之前, 我们从另一个面试高频问题来切入,我们的web页面从开始解析到页面渲染完成都经历了什么 ? 1、
推荐度:
标签: 加载 js 代码
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top