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

最近看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>