zoukankan      html  css  js  c++  java
  • 脚本加载优化方法

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

    如果我们只是单纯在 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 标签中调用函数加载其他脚本

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

    感谢您的阅读及指正,让我们一起进步。
    欢迎联系我交流:veinyin@gmail.com
    作者:VeinYin
    博客地址:https://www.cnblogs.com/veinyin/
    如需转载请注明出处。
  • 相关阅读:
    精通javascript、javascript语言精粹读书笔记
    javascript语言精粹。3、对象;4、函数;深入原型链,对象的原理!
    权限管理
    javascript碎碎念(面向对象备忘)
    几个JavaScript面试题
    JavaScript类属性的定义方法和区别
    j
    Java调用SQL存储过程 输入输出参数(转)
    Java中文乱码解决
    js中eval详解
  • 原文地址:https://www.cnblogs.com/veinyin/p/7637407.html
Copyright © 2011-2022 走看看