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
}


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM