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(){     
    函數體;     
}工具

還能夠創建一個註冊多級命名空間的機制:
//一、命名空間註冊工具類     
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();");     
    }     
}     
     
//二、註冊命名空間 com.boohee.ui     
Namespace.register("com.boohee.ui");     
     
//三、使用命名空間     
com.boohee.ui.TreeGrid = function(){     
    this.sayHello = function(name){     
        alert("Hello " + name);     
    }     
}     
     
var t = new com.boohee.ui.TreeGrid();     
t.sayHello("uid");post

===========================================================================ui

/*** 構造命名空間 ***/
/*
* if (typeof(window.Com) == "undefined")//也能夠使用:if (typeof(Com) == "undefined")
{
window.Com = {};//也能夠使用:window.Com = new Object();
}this

*/
//一級: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 = {};
}spa

//靜態方法
BrcLib.JavaScript.Message.ShowMessage = function(ms)
{
alert(ms);
}prototype

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

相關文章
相關標籤/搜索