zoukankan      html  css  js  c++  java
  • JS命名空间

    JS多级命名空间
     

    JavaScript不像C#或Java,有专门的namespace和package语法支持,当JS复杂到一定程度,尤其是引用大量的第三方JS框架和类库之后,命名冲突就会成为一个严重的问题,因此使用JS自己的变通方式建立命名空间很重要。

    最简单的实现命名空间的方法,代码示例如下:

    //这是伪代码,:
    var com;    
    if(!com) com = {}; //第一级域名    
    com.ModuleClass = {}; //第二级域名    
    com.ModuleClass.函数名1=function(){    
        函数体;    
    }  
    com.ModuleClass.函数名2=function(){    
        函数体;    
    }

    还可以建立一个注册多级命名空间的机制:
    //1、命名空间注册工具类    
    var Namespace = new Object();    
                
    Namespace.register = function(path){    
        var arr = path.split(".");    
        var ns = "";    
        for(var i=0;i<arr.length;i++){    
            if(i>0) ns += ".";    
            ns += arr[i];    
            eval("if(typeof(" + ns + ") == 'undefined') " + ns + " = new Object();");    
        }    
    }    
        
    //2、注册命名空间 com.boohee.ui    
    Namespace.register("com.boohee.ui");    
        
    //3、使用命名空间    
    com.boohee.ui.TreeGrid = function(){    
        this.sayHello = function(name){    
            alert("Hello " + name);    
        }    
    }    
        
    var t = new com.boohee.ui.TreeGrid();    
    t.sayHello("uid");

    ===========================================================================

    /*** 构造命名空间 ***/
    /*
    * if (typeof(window.Com) == "undefined")//也可以使用:if (typeof(Com) == "undefined")
    {
    window.Com = {};//也可以使用:window.Com = new Object();
    }

    */
    //一级:BrcLib
    if(typeof(BrcLib) == "undefined")
    {
        BrcLib = new Object();
    }
    //二级:BrcLib.JavaScript
    if(typeof(BrcLib.JavaScript)=="undefined")
    {
        BrcLib.JavaScript = {};
    }
    //三级:BrcLib.JavaScript.File
    if(typeof(BrcLib.JavaScript.File)=="undefined")
    {
        BrcLib.JavaScript.File = {};
    }
    //三级:BrcLib.JavaScript.Message
    if(typeof(BrcLib.JavaScript.Message)=="undefined")
    {
        BrcLib.JavaScript.File = {};
    }

    //静态方法
    BrcLib.JavaScript.Message.ShowMessage = function(ms)
    {
    alert(ms);
    }

    //必须使用new后的方法
    BrcLib.JavaScript.Message.prototype.formatString = function(format)
    {
    //code
    }

  • 相关阅读:
    ThinkPHP5远程代码执行高危漏洞(附:升级修复解决方法)
    PowerDesigner 表格导出为excel
    ubuntu 18.04 配置远程ssh/远程ftp/远程vnc登陆
    Linux apache的运行用户和用户组
    mac系统 安装pip,用python读写excel(xlrd、xlwt)安装
    nvm 设置 nodejs 默认版本
    js基础
    Node.js 8 中的 util.promisify的详解
    HTTP协议中POST、GET、HEAD、PUT等请求方法以及一些常见错误
    MQTT简介
  • 原文地址:https://www.cnblogs.com/ytjjyy/p/2453337.html
Copyright © 2011-2022 走看看