首页 > 语言 > JavaScript > 正文

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

2024-05-06 16:19:37
字体:
来源:转载
供稿:网友

为了提高页面的打开和加载速度,我们经常把JS文件放在页面的尾部,但是有些JS必须放在页面前面,这样就会增加页面的加载时间;于是出现了按需动态加载的概念,这个概念就是当页面需要用到这个JS文件或者CSS渲染文件的时候,在去请求这些文件,这样就节省了页面的加载时间

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

简单示例

 

 
  1. $LAB 
  2. .script("script1.js""script2.js""script3.js"
  3. .block(function(){ 
  4. // wait for all to load, then do something 
  5. script1Func(); 
  6. script2Func(); 
  7. script3Func(); 
  8. }); 

介绍下LABJS的几个实例:

实例1:

 

 
  1. $LAB 
  2. .script("script1.js"
  3. .script("script2.js"
  4. .script("script3.js"
  5. .wait(function(){ // 等待所有script加载完再执行这个代码块 
  6. script1Func(); 
  7. script2Func(); 
  8. script3Func(); 
  9. }); 

实例2:

 

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

实例3:

 

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

实例4:

 

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

实例5:

 

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

实例6:

 

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

实例7:

 

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

实例8:

 

 
  1. $LAB 
  2. .script(function(){ 
  3. // `_is_IE`的值ie为true ,非ie为false 
  4. if (_is_IE) { 
  5. return "ie.js"// 如果是ie则这个js会被加载 
  6. else { 
  7. return null//如果不是ie这个代码就会被略过 
  8. }) 
  9. .script("script1.js"
  10. .wait(); 

LABjs加载方式

LABjs里的动态加载脚本文件,是指页面的js脚本执行时,通过多种方法去加载外部的js(主要区别于html页面里,通过

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表

图片精选