JS加载方式对loaded和domready的影响

[b]Javascript 的加载方式大概有以下几种[/b]

[b]加载方式一[/b]

<script src='http://l.me/1.js'></script>



[b]加载方式二[/b]

document.write('<script src="http://l.me/1.js"><\/script>');



[b]加载方式三[/b]

var s = document.createElement('script');
s.setAttribute('src', 'http://l.me/1.js');
document.head.appendChild(s);



[b]加载方式四[/b]

<script src='http://l.me/1.js' defer='defer'></script>



经过测试发现:

onload时间不变,domready时间, 方案三、四比一、二短很多;

[b]原因分析[/b]:
方式一,浏览器遇到script标签是,会去请求资源,请求完之后再执行,在此期间block了对此元素后面dom元素的渲染,所以domready时间拉长了。
方式二,原因同方式一,之所以会这样是因为document.write出来的元素也会被即刻渲染,即浏览器输出之后就当作dom元素去处理。
方式三,是常用的动态加载方式,这种做法彻底将加载JS移出文档加载流,实现异步加载。有些人可能会顾虑这样加载会不会影响浏览器对该文件的缓存,其实不会的,因为浏览器缓存是针对请求的,而不是针对请求是怎么来的,就跟ajax请求也会被缓存一个道理。
方法四,添加异步属性,也就是defer,好处在于加载的时候不会block后面的元素,但是目前只有 Internet Explorer 支持 defer 属性。
测试代码如下:

<html>
<head><title>test document.write</title>
<script>
var G_top = +new Date;
</script>
</head>
<body>
<script src='http://l.me/1.js'></script>
<script>
//document.write('<script src="http://l.me/1.js"><\/script>');
/*
var s = document.createElement('script');
s.setAttribute('src', 'http://l.me/1.js');
document.head.appendChild(s);
*/
window.addEventListener('DOMContentLoaded', function (){alert(+new Date - G_top)});
</script>
</body>
</html>
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值