欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

JS优化与惰性载入函数实例分析

程序员文章站 2023-11-13 16:09:52
本文实例讲述了js优化与惰性载入函数。分享给大家供大家参考,具体如下: 惰性载入函数 由于现在浏览器之间的差异,为了实现跨浏览器工作,很多函数要书写大量if语句或者tr...

本文实例讲述了js优化与惰性载入函数。分享给大家供大家参考,具体如下:

惰性载入函数

由于现在浏览器之间的差异,为了实现跨浏览器工作,很多函数要书写大量if语句或者try…catch…语句。当每次调用函数时,都要对每个if分支或try语句进行检查,这样会使得浏览器反应变慢。实际上,当我们用某个浏览器打开网页时,就决定了某个if分支或try语句是可用的,没有必要每次调用都检查。为了解决以上问题,javascript中出现一种名为惰性载入的技巧。

惰性载入表示函数执行的分支仅会发生一次。有两种实现惰性载入的方式:在函数被调用时再处理函数;在声明函数时就指定适当函数。

借用javascript高级程序设计中的例子来说明这两种解决方案。

创建xhr对象的兼容写法如下:

function createxhr(){
  if (typeof xmlhttprequest != "undefined"){
    return new xmlhttprequest();
  } else if (typeof activexobject != "undefined"){
    if (typeof arguments.callee.activexstring != "string"){
      var versions = ["msxml2.xmlhttp.6.0", "msxml2.xmlhttp.3.0",
              "msxml2.xmlhttp"];
      for (var i=0,len=versions.length; i < len; i++){
        try {
          var xhr = new activexobject(versions[i]);
          arguments.callee.activexstring = versions[i];
          return xhr;
        } catch (ex){
          //skip
        }
      }
    }
    return new activexobject(arguments.callee.activexstring);
  } else {
    throw new error("no xhr object available.");
  }
}

使用惰性载入的第一种方法——在函数被调用时再处理函数:

function createxhr(){
  if(typeof xmlhttprequest!="undefined"){
    createxhr=function(){
      return new xmlhttprequest();
    };
  }else if(typeof activexobject!="undefined"){
    createxhr=function(){
      if(typeof arguments.callee.activexstring!="string"){
        var versions=["msxml2.xmlhttp.6.0","msxml2.xmlhttp.3.0","msxml2.xmlhttp"],
          i,len;
        for(i=0,len=versions.length;i<len;i++){
          try{
            new activexobject(versions[i]);
            arguments.callee.activexstring=versions[i];
            break;
          }catch(ex){
            //skip
          }
        }
      }
      return new activexobject(arguments.callee.activexstring);
    };
  }else{
    createxhr=function(){
      throw new error("no xhr object available.");
    };
  }
  return createxhr();
}

使用惰性载入的第二种方法——在声明函数时就指定适当函数:

var createxhr=(function(){
  if(typeof xmlhttprequest!="undefined"){
    return function(){
      return new xmlhttprequest();
    };
  }else if(typeof activexobject!="undefined"){
    return function(){
      if(typeof arguments.callee.activexstring!="string"){
        var versions=["msxml2.xmlhttp.6.0","msxml2.xmlhttp.3.0","msxml2.xmlhttp"],
          i,len;
        for(i=0,len=versions.length;i<len;i++){
          try{
            new activexobject(versions[i]);
            arguments.callee.activexstring=versions[i];
            break;
          }catch(ex){
            //skip
          }
        }
      }
      return new activexobject(arguments.callee.activexstring);
    };
  }else{
    return function(){
      throw new error("no xhr object available.");
    };
  }
})();

上例中,使用的是一个匿名、自执行的函数,用以确定应该使用哪个函数。

以上两种使用惰性载入函数的共同优点是,只在第一次执行函数时牺牲部分性能,可以提高代码效率。

更多关于javascript相关内容可查看本站专题:《javascript面向对象入门教程》、《javascript中json操作技巧总结》、《javascript切换特效与技巧总结》、《javascript查找算法技巧总结》、《javascript动画特效与技巧汇总》、《javascript错误与调试技巧总结》、《javascript数据结构与算法技巧总结》、《javascript遍历算法与技巧总结》及《javascript数学运算用法总结

希望本文所述对大家javascript程序设计有所帮助。