首页 > 语言 > JavaScript > 正文

详谈LABJS按需动态加载js文件

2024-05-06 14:42:12
字体:
来源:转载
供稿:网友

LABjs 是一个很小的 JavaScript 工具,用来根据需要加载 JavaScript 文件,通过使用该工具可以提升页面的性能,避免加载不需用到的 JavaScript 文件,可以实现动态并行加载脚本文件,以及管理加载脚本文件的执行顺序。

简单示例

$LAB.script("script1.js", "script2.js", "script3.js").block(function(){  // wait for all to load, then do something  script1Func();  script2Func();  script3Func();});

介绍下LABJS的几个实例:
实例1:

$LAB  .script("script1.js")  .script("script2.js")  .script("script3.js")  .wait(function(){ // 等待所有script加载完再执行这个代码块    script1Func();    script2Func();    script3Func();  });

实例2:

$LAB   .script({ src: "script1.js", type: "text/javascript" })  .script("script2.js")  .script("script3.js")  .wait(function(){ // 等待所有script加载完再执行这个代码块    script1Func();    script2Func();    script3Func();  });

实例3:

$LAB  .script("script1.js", "script2.js", "script3.js")  .wait(function(){ // 等待所有script加载完再执行这个代码块    script1Func();    script2Func();    script3Func();  });

实例4:

$LAB  .script( [ "script1.js", "script2.js" ], "script3.js")  .wait(function(){ // 等待所有script加载完再执行这个代码块    script1Func();    script2Func();    script3Func();  });

实例5:

$LAB  .script("script1.js").wait() // 空的wait()只是确保script1在其他代码之前被执行  .script("script2.js") // script2 和 script3 依赖于 script1  .script("script3.js").wait() // 但是script2 和 script3 并不互相依赖,可以并行下载  .script("script4.js") // script4 依赖于 script1, script2 及 script3  .wait(function(){script4Func();});

实例6:

$LAB  .script("script1.js") // script1, script2, and script3 之间没有依赖关系,  .script("script2.js") // 所以可以任意顺序执行  .script("script3.js")  .wait(function(){ // 如果需要,这里当然可以执行javascript函数    alert("Scripts 1-3 are loaded!");  })  .script("script4.js") // 依赖于 script1, script2 及 script3  .wait(function(){script4Func();});

实例7:

$LAB  .setOptions({AlwaysPreserveOrder:true}) // 设置每个脚本之间等待  .script("script1.js") // script1, script2, script3, script4 互相依赖  .script("script2.js") // 并且并行下载后循序执行  .script("script3.js")  .script("script4.js")  .wait(function(){script4Func();});

实例8:

$LAB  .script(function(){    // `_is_IE`的值ie为true ,非ie为false    if (_is_IE) {      return "ie.js"; // 如果是ie则这个js会被加载    }    else {      return null; //如果不是ie这个代码就会被略过    }  })  .script("script1.js")  .wait();            
发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表

图片精选