JavaScript创建命名空间(namespace)的最简实现
2007-12-11 00:00
866 查看
最近看Ext源代码,看到了其实现命名空间函数的实现方法:
Ext NameSpace实现代码:
鄙人喜好最简编程(这很多时候并不是一个好习惯,写的越简单程序一般越难理解),于是就想用更短的方式解决这个问题。
尝试了将近半个小时写下了下面的实现,基本该考虑的情况都考虑,至少不会覆盖页面已经存在的函数。
实现代码如下:
你可以保存以下代码进行测试:
测试代码:
Ext NameSpace实现代码:
namespace : function(){ var a=arguments, o=null, i, j, d, rt; for (i=0; i<a.length; ++i) { d=a[i].split("."); rt = d[0]; eval('if (typeof ' + rt + ' == "undefined"){' + rt + ' = {};} o = ' + rt + ';'); for (j=1; j<d.length; ++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<len,ni=ns[i];i++){ try{o=(o?(o[ni]=o[ni]||{}):(eval(ni+"="+ni+"||{}")))}catch(e){o=eval(ni+"={}")} } }
你可以保存以下代码进行测试:
测试代码:
<script type="text/javascript"> <!-- function namespace(ns){ if(typeof(ns)!="string")return; ns=ns.split("."); var o,ni; for(var i=0,len=ns.length;i<len,ni=ns[i];i++){ try{o=(o?(o[ni]=o[ni]||{}):(eval(ni+"="+ni+"||{}")))}catch(e){o=eval(ni+"={}")} } } function a(){return 5} namespace("a.b"); alert(a); alert(a.b) namespace("test.test.abc") test.test.abc.func1=function(){ alert('func1 run') } alert(test.test) test.test.abc.func1(); //--> </script>
相关文章推荐
- JavaScript创建命名空间(namespace)的最简实现
- JavaScript 实现命名空间(namespace)的最佳方案——兼容主流的定义类(class)的方法,兼容所有浏览器,支持用JSDuck生成文档
- 在JavaScript中实现命名空间
- 在JavaScript中实现命名空间
- JavaScript 匿名函数、模块模式、闭包、命名空间、创建构造器(类)、继承
- 在JavaScript中实现命名空间
- 利用MS AJAX注册Javascript命名空间并创建类
- 在JavaScript中创建命名空间的几种写法
- 在JavaScript中实现命名空间
- 在JavaScript中创建命名空间的几种写法
- JavaScript-JS命名空间的构造和实现-[web前端开发]
- 在JavaScript中实现命名空间
- JavaScript中实现命名空间
- 在JavaScript中创建命名空间的几种写法
- javascript的对象创建模式---命名空间模式
- JavaScript创建命名空间的5种写法
- 在JavaScript中实现命名空间
- 在JavaScript中创建命名空间的几种写法
- 关于javascript模块和命名空间(Module and namespace)
- JavaScript创建命名空间