JS模拟命名空间
简单记录下自己的理解:
为了避免命名的冲突,Javascript可以通过使用对象来模拟实现命名空间,个人感觉这也是“动态语言”比较灵活的一个点。
1 //--------命名空间JsFramework1------------- 2 var JsFramework1 = window.JsFramework1 || {}; 3 JsFramework1.loadMethod1 = function () { 4 alert("loadMethod1"); 5 }; 6 JsFramework1["loadMethod2"] = function () { 7 alert("loadMethod2"); 8 }; 9 //--------命名空间JsFramework1------------- 10 11 //--------命名空间JsFramework1.Util-------- 12 JsFramework1.Util = {}; 13 JsFramework1.Util.loadMethod1 = function () { 14 alert("Util-loadMethod1"); 15 }; 16 JsFramework1.Util["loadMethod2"] = function () { 17 alert("Util-loadMethod2"); 18 }; 19 //--------命名空间JsFramework1.Util-------- 20 21 JsFramework1.loadMethod1(); //loadMethod1 22 JsFramework1.loadMethod2(); //loadMethod2 23 JsFramework1.Util.loadMethod1(); //Util-loadMethod1 24 JsFramework1.Util.loadMethod2(); //Util-loadMethod2
命名空间注册机制:
1 //--------命名空间JsFramework1子命名空间注册机制-------- 2 JsFramework1.registerNS = function () { 3 var a = arguments, o = null, i, j, d; 4 for (i = 0; i < a.length; ++i) { 5 d = a[i].split("."); 6 o = JsFramework1; 7 for (j = (d[0] == "JsFramework1") ? 1 : 0; j < d.length; ++j) { 8 o[d[j]] = o[d[j]] || {}; 9 o = o[d[j]]; 10 } 11 } 12 }; 13 JsFramework1.registerNS("JsFramework1.Util1", "JsFramework1.Util.StringHelper"); 14 //--------命名空间JsFramework1子命名空间注册机制-------- 15 16 JsFramework1.Util.StringHelper = function () { 17 alert("JsFramework1.Util.StringHelper"); 18 }; 19 JsFramework1.Util.StringHelper(); //JsFramework1.Util.StringHelper
参考:
1、http://www.cnblogs.com/leafyoung/archive/2006/10/11/526570.html
2、http://www.neoease.com/javascript-namespace/