作家
登录

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

作者: 来源:www.28hudong.com 2013-03-30 03:13:04 阅读 我要评论

最近看Ext源代码,看到了其实现命名空间函数的实现方法: 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常用运算符(Operators)-javascript基础教程

javascript基础教程算术运算符 运算符 运算符说明 示例 示例说明 + 加法 x+y 如果x为整数2,y为整数5, x+y等于7 如果x为字符串"text1", y为字符串"fun", x+y则等于"text1fun" - 减法 x-y * 乘法 x*y />>>详细阅读


本文标题:JavaScript创建命名空间(namespace)的最简实现

地址:http://www.17bianji.com/kaifa2/JS/29942.html

关键词: 探索发现

乐购科技部分新闻及文章转载自互联网,供读者交流和学习,若有涉及作者版权等问题请及时与我们联系,以便更正、删除或按规定办理。感谢所有提供资讯的网站,欢迎各类媒体与乐购科技进行文章共享合作。

网友点评
自媒体专栏

评论

热度

精彩导读
栏目ID=71的表不存在(操作类型=0)