本文地址:
如果我们只是单纯在 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 标签中调用函数加载其他脚本
当然,也有一些懒加载库能使用。