欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  web前端

JavaScript创建命名空间(namespace)的最简实现_javascript技巧

程序员文章站 2022-06-13 12:35:48
...
最近看Ext源代码,看到了其实现命名空间函数的实现方法:

Ext NameSpace实现代码:
复制代码 代码如下:

namespace : function(){
var a=arguments, o=null, i, j, d, rt;
for (i=0; i d=a[i].split(".");
rt = d[0];
eval('if (typeof ' + rt + ' == "undefined"){' + rt + ' = {};} o = ' + rt + ';');
for (j=1; j o[d[j]]=o[d[j]] || {};
o=o[d[j]];
}
}
}



鄙人喜好最简编程(这很多时候并不是一个好习惯,写的越简单程序一般越难理解),于是就想用更短的方式解决这个问题。
尝试了将近半个小时写下了下面的实现,基本该考虑的情况都考虑,至少不会覆盖页面已经存在的函数。

实现代码如下:
复制代码 代码如下:

function namespace(ns){
if(typeof(ns)!="string")return;
ns=ns.split(".");
var o,ni;
for(var i=0,len=ns.length;i try{o=(o?(o[ni]=o[ni]||{}):(eval(ni+"="+ni+"||{}")))}catch(e){o=eval(ni+"={}")}
}
}


你可以保存以下代码进行测试:

测试代码:

复制代码 代码如下: