您的位置:首页 > Web前端 > JavaScript

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

2007-12-11 00:00 866 查看
最近看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>
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: