日期:2014-05-16  浏览次数:20374 次

JavaScript学习笔记之三:命名空间

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"); 

?

?

?