动态加载js的方法

  最近在维护一个项目,看到一个页面竟然要加载20多个js文件!!!真惊人,仔细观察后,发现有很多js文件根本用不上的,或者在某个条件成立才使用的;为了提高此页面的性能,决定使用动态加载js文件的方法,即在需要的时候才加载该js文件。

      网上看了很多关于动态加载js的方法,例子挺多的,但是都有些不足的地方。

      动态加载js文件一般用于引入的js文件太多或者不是必要的,而在满足某种条件下,需要此js文件了,才加载。

      比较满意的方法有两个:

     (1)通用方法:

     

[javascript] view plain copy print ?
  1. function JsLoader(){  
  2. this.load=function(url){  
  3.          //获取所有的<script>标记   
  4.          var ss=document.getElementsByTagName("script");  
  5.          //判断指定的文件是否已经包含,如果已包含则触发onsuccess事件并返回   
  6.          for (i=0;i<ss.length;i++){  
  7.              if (ss[i].src && ss[i].src.indexOf(url)!=-1){  
  8.                  this.onsuccess();  
  9.                  return;  
  10.              }  
  11.          }  
  12.          //创建script结点,并将其属性设为外联JavaScript文件   
  13.          s=document.createElement("script");  
  14.          s.type="text/javascript";  
  15.          s.src=url;  
  16.          //获取head结点,并将<script>插入到其中   
  17.          var head=document.getElementsByTagName("head")[0];  
  18.          head.appendChild(s);  
  19.            
  20.          //获取自身的引用   
  21.          var self=this;  
  22.          //对于IE浏览器,使用readystatechange事件判断是否载入成功   
  23.          //对于其他浏览器,使用onload事件判断载入是否成功   
  24.          //s.οnlοad=s.onreadystatechange=function(){   
  25.          s.οnlοad=s.onreadystatechange=function(){  
  26.              //在此函数中this指针指的是s结点对象,而不是JsLoader实例,   
  27.              //所以必须用self来调用onsuccess事件,下同。   
  28.              if (this.readyState && this.readyState=="loading"return;  
  29.              self.onsuccess();  
  30.          }  
  31.          s.οnerrοr=function(){  
  32.              head.removeChild(s);  
  33.              self.onfailure();  
  34.          }  
  35.      }  
  36. }  
  37.   
  38. /**使用方法 
  39.  *  var jsLoader=new JsLoader(); 
  40.  *sLoader.onsuccess=function(){}成功时执行的方法 
  41.  *jsLoader.onfailure=function(){}失败时执行的方法 
  42.  * jsLoader.load("hello.js"); 
  43. **/  
     

 

      (2)使用jquery 方法动态加载

           前提是必须先引入 jquery.js 包,然后调用jquery里面的方法:

           $.getscript("test.js"); //其中 test.js 是要加载的js文件

 


       小结:方法1看起来比较复杂,但是基本上把此代码写在一个js文件,然后就可以直接使用了。方法2很简单,但是要引入jquery.js文件和要有jquery的基础。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值