百良西瓜

导航

JavaScript 高性能笔记

浏览器解析 JavaScript 、CSS 、DOM 时,一般都是单线程解析,所以,引用外部文件时的位置不同,UE体验也不同。

下面是 Yahoo 大牛 Nicholas C. Zakas 的 《High Performance JavaScript》书中的总结。

1、把不影响DOM布局的 JS 文件引用放到 </body> 之前,这样浏览器可先加载HTML页面,解析DOM,给人相对快的感觉。

  <html>

  <head>

    <title></title>

  </head>

  <body>

    ...

    <script src="jquery.js"></script>

    <script src="jqueryui.js"></script>

  </body>

  </html>

2、动态加载 JS,意思是动态生成<script>标签,加载外部 JS 文件,利用了浏览器解析 DOM 元素的 src 时不阻塞的特性。

  一般可在<head></head>标签中动态生成<script>标签,如下,

<head>
    <script>
        // 加载 JS 的封装函数
        function loadScript(url, callback) {
            var script = document.createElement("script");
            script.type = "text/javascript";
            
            if(script.readyState) { // IE
                script.onreadystatechange = function() {
                    if(script.readyState == "loaded" || script.readState == "complete") {
                        script.onreadystatechange = null;
                        // JS 文件加载完之后,可以处理一些事情
                        callback();
                    }
                }
            }
            else { // firefox\ chrome \opera
                script.onload = function() {
                    // JS 文件加载完之后,可以处理一些事情
                    callback();
                };
            }
            
            script.src = url;
            document.getElementsByTagName("head")[0].appendChild(script);            
        }
    
        // 
        loadScript("http://xxx.com/jquery.com", function() { ... });
        
    </script>
</head>

  通过以上方法,也可按照顺序加载多个 JS 文件,

loadScript("file1.js", function() {
    loadScript("file2.js", function() {
        loadScript("file3.js", function() {
            // 加载完毕
            ......
        });
    });
});

3、使用 LazyLoad.js 开源库以非阻塞方式加载外部 JS 文件,从  github : LazyLoad.js  下载,   

    <script src="js/lazyload-min.js"></script>
    <script>
      LazyLoad.js("the-rest.js", function() {
        // 加载完之后,做一些逻辑操作
        ......
      });
    </script>

  也可以同时加载多个 JS 文件,写成数组的形式,

    LazyLoad.js(["the-rest.js", "file2.js", "file3.js"], function() {
      // 加载完之后,做一些逻辑操作
      ......
    });

  注意,LazyLoad 会保证在所有的浏览器中按照顺序加载所有 JS 文件,每一个 JS 文件都是一个单独的 HTTP 请求,

  并且全部加载完之后才会执行回调函数 callback。

  LazyLoad 也可以用来动态加载 CSS 文件,CSS文件的下载以并行的方式完成,并且不会阻塞其他页面。

4、使用 LAB.js 开源库以非阻塞方式加载外部 JS 文件,从  lab.js  下载,  

    <script src="js/LAB.min.js"></script>
    <script>
      $LAB.script("the-rest.js").wait(function() {
        // 加载完之后,做一些逻辑操作
        ......
      });
    </script>

  $LAB 的方法都返回一个 $LAB 对象,所以可以进行链式调用。

  $LAB.wait() 方法保证只有等 JS 文件下载并执行完之后,才会执行最终的回调函数。

  也可以同时加载多个 JS 文件,  

    $LAB.script("first.js").script("the-rest.js").wait(function() {
      // 加载完之后,做一些逻辑操作
      ......
    });

  一般情况下,LAB 会按照顺序执行多个JS 文件,但并不保证,所以,如果你要保证运行的前后顺序,

  那么请使用 wait() 方法,如下,

    $LAB.script("first.js").wait().script("the-rest.js").wait(function() {
      // 加载完之后,做一些逻辑操作
      ......
    });

  这样,就可保证 first.js 在 the-rest.js 之前运行。下载的顺序可以并行。

posted on 2015-12-17 16:42  百良西瓜  阅读(155)  评论(0编辑  收藏  举报