最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

Javascript无阻塞加载具体方式_javascript技巧

来源:动视网 责编:小采 时间:2020-11-27 21:10:32
文档

Javascript无阻塞加载具体方式_javascript技巧

Javascript无阻塞加载具体方式_javascript技巧:看了《高性能JavaScript》的读书笔记 几个原则: 1、将脚本放在底部 还是在head中,用以保证在js加载前,能加载出正常显示的页面。 放在前。 2、成组脚本 由于每个标签下载时阻塞页面解析过程,所以限制页面的总数也可以改善性能。适用于内联脚本和外部脚本。
推荐度:
导读Javascript无阻塞加载具体方式_javascript技巧:看了《高性能JavaScript》的读书笔记 几个原则: 1、将脚本放在底部 还是在head中,用以保证在js加载前,能加载出正常显示的页面。 放在前。 2、成组脚本 由于每个标签下载时阻塞页面解析过程,所以限制页面的总数也可以改善性能。适用于内联脚本和外部脚本。


看了《高性能JavaScript》的读书笔记

几个原则:

1、将脚本放在底部

还是在head中,用以保证在js加载前,能加载出正常显示的页面。

放在前。

2、成组脚本

由于每个标签下载时阻塞页面解析过程,所以限制页面的总数也可以改善性能。适用于内联脚本和外部脚本。

3、非阻塞脚本

等页面完成加载后,再加载js代码。也就是,在window.load事件发出后开始下载代码。

(1)defer属性:支持IE4和fierfox3.5更高版本浏览器

...

内联和外部文件

带defer属性的可出现在文档的任何位置,对应的js文件将在被解析时启动下载,但代码不会执行,直到DOM加载完毕(在onload事件句柄被调用之前)。所以实现了和也卖弄其他资源一起并行下载。

(2)动态脚本元素

文档对象模型(DOM)允许你使用js动态创建HTML的几乎全部文档内容。
代码如下:
var script=document.createElement("script");

script.type="text/javascript";

script.src="file.js";

document.getElementByTagName_r("head")[0].appendChild(script);

此技术的重点在于:无论在何处启动下载,文件额下载和运行都不会阻塞其他页面处理过程。即使在head里(除了用于下载文件的http链接)。

(3)The YUI3 approach

理念:用一个很小的初始代码,下载其余的功能代码,先引入文件:
代码如下:


此种子文件大约10KB,

使用:
代码如下:
YUI().use("dom",function(Y){

  Y.Dom.addclass(...)

})

当所有代码可用时,回调函数被调用,YUI实例作为参数传入,就可以立即使用新下载的功能。

The LazyLoad library

使用:先引入:lazyload-min.js

(4)
代码如下:
LazyLoad.js("a.js",function(){

Appliction.init();

})

多个文件:
代码如下:
LazyLoad.js(["a.js","b.js"],function(){

Application.init();

})

(5)The LABjs library

先引入:lab.js
代码如下:
$LAB.script("a.js").wait(function(){

Application.init();

})

多个文件,就链式写法

他的独特之处在于能够管理依赖关系。

可以通过wait()函数指定哪些文件应该等待其他文件。

例如:b.js的代码保证不在a.js之前运行
代码如下:
$LAB.script("a.js").wait().script("b.js").wait(function(){

Application.init();

})

这样,虽然两个文件是并行下载的,却能保证a.js能在b.js之前执行

文档

Javascript无阻塞加载具体方式_javascript技巧

Javascript无阻塞加载具体方式_javascript技巧:看了《高性能JavaScript》的读书笔记 几个原则: 1、将脚本放在底部 还是在head中,用以保证在js加载前,能加载出正常显示的页面。 放在前。 2、成组脚本 由于每个标签下载时阻塞页面解析过程,所以限制页面的总数也可以改善性能。适用于内联脚本和外部脚本。
推荐度:
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top