js高级编程中命名空间的两种用法

第一种:
// 声明一个全局对象Namespace,用来注册命名空间
js高级编程中命名空间的两种用法Namespace = new Object();
js高级编程中命名空间的两种用法
js高级编程中命名空间的两种用法// 全局对象仅仅存在register函数,参数为名称空间全路径,如"Grandsoft.GEA"
js高级编程中命名空间的两种用法Namespace.register = function(fullNS)
js高级编程中命名空间的两种用法{
  // 将命名空间切成N部分, 比如Grandsoft、GEA等
   var nsArray = fullNS.split('.');
var sEval = "";
 var sNS = "";
 for (var i = 0; i < nsArray.length; i++)
{
if (i != 0) sNS += ".";
sNS += nsArray[i];
// 依次创建构造命名空间对象(假如不存在的话)的语句
 // 比如先创建Grandsoft,然后创建Grandsoft.GEA,依次下去js高级编程中命名空间的两种用法
 sEval += "if (typeof(" + sNS + ") == 'undefined') " + sNS + " = new Object();"
}
if (sEval != "") eval(sEval);
}
// 注册命名空间Grandsoft.GEA, Grandsoft.GCM
js高级编程中命名空间的两种用法Namespace.register("Grandsoft.GEA");
js高级编程中命名空间的两种用法Namespace.register("Grandsoft.GCM");
js高级编程中命名空间的两种用法
js高级编程中命名空间的两种用法// 在Grandsoft.GEA命名空间里面声明类Person
js高级编程中命名空间的两种用法Grandsoft.GEA.Person = function(name, age)
js高级编程中命名空间的两种用法js高级编程中命名空间的两种用法{
  this.name = name;
   this.age = age;
}
js高级编程中命名空间的两种用法
js高级编程中命名空间的两种用法// 给类Person添加一个公共方法show()
js高级编程中命名空间的两种用法Grandsoft.GEA.Person.prototype.show = function()
js高级编程中命名空间的两种用法js高级编程中命名空间的两种用法{
   alert(this.name + " is " + this.age + " years old!");
}
js高级编程中命名空间的两种用法
js高级编程中命名空间的两种用法// 演示如何使用类Person
js高级编程中命名空间的两种用法var p = new Grandsoft.GEA.Person("yanglf", 25);
js高级编程中命名空间的两种用法p.show();js高级编程中命名空间的两种用法
第二种:
eye = {
    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]];
            }
        }
    }
};

eye.namespace("eye", "eye.common", "eye.datePicker", "eye.selectCity", "eye.tab","eye.test");
eye.test={//测试命名空间
    show: function() {
        return "aaa";
    }
}
alert(eye.test.show());//命名空间