有firebug的童鞋可以看到,页面内容及图片等被head里面的外调script及css文件所阻塞,页面加载耗时5.5S,如下图页面阻塞测试 以下内容被阻塞
![12105032_tf17.jpg](http://static.oschina.net/uploads/img/201311/12105032_tf17.jpg)
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移出文档加载流,实现异步加载,就不会再阻塞页面其他内容了,看如下完整代码:
当然如果可能的话,就尽量将script置于底部,就没有阻塞的问题了,就像yslow所建议那样,put style top,put script bottom!!页面阻塞测试 以下内容将不会被阻塞