1 javascript中本沒有命名空間的概念,但是要體現物件導向的思想,
應當有命名空間,就像java中的package,.net中的namespace一樣,
作用主要為了防止類名衝突,相同的類名只要屬於不同的命名空間,便不會衝突。
2
3
4
5 最簡單建立命名空間的方法:
6 var java = {};
7 java.util = {};
8
9 //這樣就建立成功了命名空間:java.util
10 //我們可以在java.util下面加類(函數),屬性,或對象
11 java.util.HashMap = function()
12 {
13 this.ShowMessage = function()
14 {
15 alert("java.util.HashMap");
16 }
17 }
18
19 var map = new java.util.HashMap();
20
21 alert(map.ShowMessage()); //顯示結果:java.util.HashMap
22
23
24 //封裝建立命名空間的方法:
25 //定義一個對象,js中用{}花括弧定義對象,等同於 var JsObject = new Object();
26 var JsObject = {}; 27 JsObject.namespace = function() //在JsObject對象下定義一個函數namespace
28 {
29
30 /*下面代碼中arguments為函數傳入的參數,在function未明確定義參數時,
function也可以傳入參數,並用arguments來 接收,arguments類似數組,
如果傳入多個參數,將按順序儲存,取值法:arguments[0],arguments[1]....*/
31 var a = arguments,o = null,d,rt;
32
33 for(var i = 0; i < a.length; i++)
34 {
35 d = a[i].split('.'); //將傳入的參數用符號'.' 進行分割,並放入d數組中。
36 rt = d[0];
37
38 //判斷數組中的第一個值是否未定義,如果未定義,便定義為空白對象{},並賦值給變數o
39 eval('if (typeof ' + rt + ' == "undefined"){'
+ rt + ' = {};} o = ' + rt + ';');
40 for(var j = 1; j < d.length; j++)
41 {
42
43 /*迴圈遍曆數組d每個值作為key,加入到對象o中,如果key在o中存在,則取o中值,若
44
45 不存在,則賦值為空白對象{} */
46
47
48 o[d[j]] = o[d[j]] || {};
49 o = o[d[j]];
50 }
51 }
52 }
53 JsObject.namespace("org.myJs"); //申明命名空間:org.myJs
54
55 org.myJs.Student = function() //在命名空間org.myJs下定義類Student
56 { //定義類Student中的變數,並賦予初值,但此變數的存取權限是public
57 this.studentNo = 's001'; 58 this.studentName = '小明';
59 this.sex = '男';
60 }
61 var s = new org.myJs.Student(); //建立Student類的對象
62 alert('學號:'+s.studentNo);
63 alert('姓名:'+s.studentName);
64 alert('性別:'+s.sex);
65
66 效果和第一篇 (一)javascript經驗總結物件導向—類 結果一樣
67
68