JavaScript AJAX之惰性载入函数

作者:junjie 时间:2024-04-30 10:15:36 

在JS中有些内存只需执行一遍即可,如浏览器类型检测是最常用的一个功能,因为我们使用Ajax的时候需要检测浏览器的内置的XHR。我们可以在第一次检测的时候记录下类型,往后在使用Ajax的时候就不需要再去检测浏览器类型了。在JS中就算只有一个if也总比没有if的语句效率要高。

普通Ajax方法


/**
 * JS惰性函数
 */
 
function ajax(){
    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,k=version.length;i<k;i++){
                try{
                    new ActiveXObject(versions[i]);
                    arguments.callee.activeXString = versions[i];
                    break;
                }catch(ex){
                    throw ex;  
                }
            }
        }  
 
        return new ActiveXObject(arguments.callee.activeXString);
    }else{
        throw "No XHR object"; 
    }
}


每次调用ajax()函数都要对浏览器内置的XHR检查,效率不高。

使用惰性方式的方法


/**
 * JS惰性函数
 */
 
function ajax(){
    if(typeof XMLHttpRequest != "undefined"){
        ajax = function(){
            return new XMLHttpRequest();   
        };
    }else if(typeof ActiveXObject != "undefined"){
        ajax = function(){
            if(typeof arguments.callee.activeXString != "string"){
                var versions = ["MSXML2.XMLHttp.6.0","MSXML2.XMLHttp.3.0","MSXML2.XMLHttp"];   
 
                for(var i=0,k=version.length;i<k;i++){
                    try{
                        var xhr = new ActiveXObject(versions[i]);  
                        arguments.callee.activeXString = versions[i];
                        return xhr;
                    }catch(ex){
                        throw ex;  
                    }
                }
            }  
 
            return new ActiveXObject(arguments.callee.activeXString);
        }
    }else{
        ajax = function(){
            throw "No XHR object"; 
        }
    }
 
    return ajax();
}


在第二个惰性方法中if的每个分支都会为ajax()变量赋值,有效覆盖了原有函数,最后一步调用新的函数。下一次调用的ajax()的时候,就直接调用变量。

优化重点

要执行特定代码只有实际调用才执行,而某些JS库一开始就检测浏览器,预先设置好。

由于加了复杂的判断所以首次运行速度慢,但后边的多册运行的效率会更快。
 
有时候写代码久了,不能一成不变,要经常思考怎样才能使程序运行的更快,更有效率。这样的思考下写出来的程序才是精装,而不会产生多余的垃圾代码。这也不是简单OO就能一刀切,实际上代码很多地方都是活的,人更是活的。

标签:JavaScript,AJAX,惰性载入
0
投稿

猜你喜欢

  • Python OpenCV超详细讲解读取图像视频和网络摄像头

    2023-11-26 05:22:36
  • mysql数据库是做什么

    2024-01-16 04:18:16
  • Python运算符+与+=的方法实例

    2022-02-26 04:40:59
  • 如何将PySpark导入Python的放实现(2种)

    2022-10-21 02:12:16
  • asp.net“服务器应用程序不可用” 解决方法

    2023-06-29 10:05:30
  • Python调用百度api实现语音识别详解

    2023-03-10 05:10:17
  • Apple在Safari 4中抛弃品牌视觉设计

    2009-02-26 13:05:00
  • 10个杀手级应用的Python自动化脚本

    2023-10-06 14:01:53
  • pyqt5 获取显示器的分辨率的方法

    2023-10-25 09:51:36
  • JSP EL表达式详细介绍

    2023-07-02 22:32:32
  • python的移位操作实现详解

    2021-05-05 22:51:30
  • python中的queue队列类型及函数用法

    2023-09-04 21:04:01
  • python Crypto模块的安装与使用方法

    2022-09-17 15:19:01
  • php集成环境xampp中apache无法启动问题解决方案

    2023-07-17 22:44:52
  • javascript demo 基本技巧

    2024-04-29 13:24:45
  • python绘制浅色范围曲线的示例代码

    2021-07-03 02:34:10
  • 教你设计大型Oracle数据库

    2009-07-02 12:31:00
  • 仿windows选项卡效果拾零

    2013-07-13 09:33:42
  • Mysql数据库监听binlog的开启步骤

    2024-01-26 03:50:36
  • asp 网站静态化函数代码html

    2011-03-16 11:21:00
  • asp之家 网络编程 m.aspxhome.com