A JavaScript Fancier

伟大的javascript技术研究中...

  IT博客 :: 首页 :: 新随笔 :: 联系 :: 聚合  :: 管理 ::
  304 随笔 :: 0 文章 :: 479 评论 :: 0 Trackbacks


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

posted on 2007-12-05 17:39 Yemoo'S JS Blog 阅读(4423) 评论(0)  编辑 收藏 引用 所属分类: javascript技巧总结
只有注册用户登录后才能发表评论。