js异步加载和时间线

JSON理解和使用

我们先说一下json:
JSON是一种传输格式,它是服务端和客户端之间的数据传输的。
JSON规范代码是类似对象的数据就像把对象用单引号引起来的
例子:
‘{“name”: “lilei”,“age”:18}’

在这里有两个方法一个是stringify和parse
这两个的作用理解:
1、stringify的使用方法和理解
使用方法
var she = JSON.stringify();
理解:
这个方法是将一个JavaScript值(对象或者数组)转换为一个 JSON字符串
2、parse的使用方法和理解
使用方法;
var she = JSON.parse();
理解:
这个方法用来解析JSON字符串,构造由字符串描述的JavaScript值或对象。提供可选的reviver函数用以在返回之前对所得到的对象执行变换

在先说js的异步加载的之前先说一下js的同步加载:

js同步加载

加载到js文件的是会等待js文件加载完成且执行完成 再继续执行后面的代码(html css js)
js同步加载的原因: js是能够修改DOM结构 renderTree

这样的话就相当于说程序加载出现了阻塞,所以我们要防止阻塞或重排

js异步加载

1、什么是异步加载
使js文件脱离html解析的文档流加载,从而使js可以并行下载。
2、为什么要异步加载
一般写法将js放在head中,而且默认方式是同步加载,这就会导致在进行js加载的过程中,无法在其加载完成前对后续的内容进行操作,造成页面内阻塞,对用户体验很不友好。
3、如何使其加载方式变成异步加载
①使用defer方法来
这个方法是只兼容IE9以下版本的
用法:

<script  type="text/javascript" defer>
	var num = 13;
	console.log(num);
</script>

②使用async方法来
这个方法是兼容苹果、谷歌、火狐、欧朋这几大浏览器的
用法:

<script  type = "text/javascript" async>
	var num = 15;
	console.log(num);
</script>

③通用的方法
创建一个script标签,插入到DOM中,加载完毕后callback 兼容性最好的
用法例子:

<script type="text/javascript">
            function loadScript(url, callback){
                var script = document.createElement('script');
                script.type = "text/javascript";//这个可要可不要
                script.src = url;//下载了指定地址的js文件
                //挂到DOM树上,此时才执行了js文件中的代码
                document.head.appendChild(script);
            }
            loadScript('js的外部文件名', 'intr');

js时间线

前言:时间线在js中占很重要的地位:优化DOM、逻辑正确时输出的为什么是undefind,很有可能都是时间线在作祟

  1、创建Document对象,再开始解析web页面。解析hrml里面的标签元素和他们的文本内容后添加Element对象和文本节点到文档中,这个阶段document.readyState = ‘loading’
2、遇到link外部css,创建线程加载,并继续解析文档。
3、遇到script外部js,并且没有设置async、defer,同时浏览器加载,并阻塞,这时会等待js加载完成并执行该脚本,然后继续解析文档。这时解析的是js同步文件
4、遇到script外部js,并且同时设置有async、defer,浏览器会创建线程加载,并继续解析文档。对于async属性的脚本,脚本加载完成后立即执行。            -
5、遇到img等,先正常解析dom结果,然后浏览器异步加载src(图片资源),并继续解析文档。
注意:img本来就是会进行异步加载的方式加载的
6、当文档解析完成,这个阶段就是document.readyState = ‘interactive’.
7、文档解析完成后,所有设置有defer异步加载的脚本按照顺序执行。
8、document对象触发DOMContentLoaded事件,这也标志着程序执行从同步脚本执行阶段,转换为事件驱动阶段。
注意:事件驱动阶段则就是浏览器正常发挥功能
9、当所有async的脚本的加载完成并执行后、img等加载完成后,这个阶段document.readyState = ‘complete’,window对象触发load事件,这个时候也就是页面的所有的内容解析完和加载完成了  
10、从此,以异步响应式处理用户输入、网络事件等。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值