分享

页面无阻塞加载研究

 CevenCheng 2012-05-24


在页面加载性能当中,页面被阻塞是影响页面主要内容(包括图片等)及时呈现在用户面前的一个重要因素之一,所以我们需要在页面中合理处置外调CSS及JS文件。
来看一段代码

   提示:你可以先修改部分代码再运行。

有firebug的童鞋可以看到,页面内容及图片等被head里面的外调script及css文件所阻塞,页面加载耗时5.5S,如下图

样式表下面如果有script标签则同样会阻塞后续页面内容的加载,但我们通常希望优先加载样式表,这样才不会看到裸奔的页面,所以我们只须关注script的无阻塞加载即可。

看下面这一段js

[隐藏代码]
function loadScript(url, callback) {
       
//创建script
       
var script = document.createElement("script");
        script
.type = "text/javascript";
        script
.src = url;
        document
.getElementsByTagName("head")[0].appendChild(script);
       
//加载完毕回调
       
if(script.readyState) { //for IE
                script
.onreadystatechange = function() {
                       
if(script.readyState == "loaded" || script.readyState == "complete") {
                                script
.onreadystatechange = null; //此处销毁事件引用,防止IE下事件驻留内存
                               
if(callback){callback();}
                       
}
               
};
       
} else { //for Others
                script
.onload = function() {
                       
if(callback){callback();}
               
};
       
}
}

以上代码可以看出,我们是用一个js动态创建一个script标签,然后赋值src来进行加载外部JS,同时提供一个回调函数,以保证在脚本加载完毕才执行的那些函数代码可以正常运行。

再看一下优化后的页面

   提示:你可以先修改部分代码再运行。

再次用firebug可以看到图片已经没有被脚本阻塞,与脚本是并行加载的,整个页面加载时间也减少不少,页面总耗时减少为2.9S,如下图

但还是有问题,在loadScript与页面内容之间如果还有script标签的话,一样会阻塞内容下载,解决方案就是给loadScript加个setTimeout执行,彻底将加载JS移出文档加载流,实现异步加载,就不会再阻塞页面其他内容了,看如下完整代码:

    本站是提供个人知识管理的网络存储空间,所有内容均由用户发布,不代表本站观点。请注意甄别内容中的联系方式、诱导购买等信息,谨防诈骗。如发现有害或侵权内容,请点击一键举报。
    转藏 分享 献花(0

    0条评论

    发表

    请遵守用户 评论公约

    类似文章 更多