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/

 

posted @ 2014-10-22 12:04  逍遥心  阅读(268)  评论(0编辑  收藏  举报