JS多级命名空间
2017-02-08 20:28
260 查看
avaScript不像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
}
最简单的实现命名空间的方法,代码示例如下:
//这是伪代码,:
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
}
相关文章推荐
- 关于JS的顶级,多级命名空间的一些心得
- 加载js库文件并提供命名空间——OpenLayers.js(一)
- [开发故事],第十五回,在Js中应用命名空间
- js命名空间
- js中命名空间使用
- js命名空间的使用
- js实现命名空间(ajax封装类)
- Js 命名空间注册方法
- JS模块与命名空间的介绍
- JS模块与命名空间
- js高级编程中命名空间的两种用法
- JS中定义命名空间
- js中定义自己的命名空间
- JS模块与命名空间的介绍
- JS命名空间、对象封装
- 有关js命名空间管理文件同步载入[转]
- js中命名空间模式下js方法声明的两个写法
- js 命名空间
- JS中命名空间(namespace)的概念和使用
- JavaScript-JS命名空间的构造和实现-[web前端开发]