码迷,mamicode.com
首页 > 其他好文 > 详细

脚本加载优化

时间:2017-10-08 15:32:46      阅读:152      评论:0      收藏:0      [点我收藏+]

标签:str   三次   浏览器   完成后   head   开始   延迟   空白   获取   

如果我们只是单纯在 head 或 body 中引用脚本,由于是否会更改DOM是未知的, 所以脚本在下载执行的过程中会完全阻塞页面的渲染。

若脚本在 head 或 body 中间,有很大可能会出现空白页面,也无法进行用户交互,用户体验很差。

即便是可以并行下载 javascript 文件,但这个下载过程中会影响图片等资源的下载。

所以我们首先需要做的是:

把 script 标签放在 body 里最底部;

因为进行 HTTP 请求时有额外的性能开销,如三次握手,所以还要尽量减少  HTTP 请求:

把 javascript 文件合并成一个;

在一个请求里加载多个 javascript 文件

但是以上并没有解决我们的问题,一个大的 javascript 文件会下载执行脚长时间,在这段时间里,浏览器无法做其他事情。这就需要无阻塞脚本,也就是在页面加载完成后才加载 javascript 代码,即在 window对象 的 load 事件触发之后再下载脚本。

1 延迟脚本

defer:首先我们要确定该脚本不会改变DOM,因为加上就是告诉浏览器这个脚本不会改变 DOM,可以在页面加载完成后再执行。 给 script 标签加上这个属性后,这个文件就可以跟其他资源并行下载了。IE 从 IE10 开始不支持 defer

async:与 defer 区别在于下载完成后就执行,但 defer 要等到页面加载完成后才执行

 

2 动态脚本

也就是动态创建一个 script 标签,在合适的时机插入到页面中,我们可以这种方法来根据需要加载文件,也能指定脚本加载顺序。

 

3 XMLHttpRequest脚本注入

就是通过 XHR 获取脚本  然后在回调函数中创建 script 标签并插入到页面中

 

推荐方法

先添加动态加载所需的脚本,尽可能精简,其中添加一个加载脚本的函数

在 script 标签中调用函数加载其他脚本

 

当然,也有一些懒加载库能使用。

脚本加载优化

标签:str   三次   浏览器   完成后   head   开始   延迟   空白   获取   

原文地址:http://www.cnblogs.com/veinyin/p/7637407.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!