Javascript物件-對應Java靜態物件

Javascript物件-對應Java靜態物件

這篇介紹Javascript物件-對應Java靜態物件。
Javascript的static物件,類別名稱開頭儘量用大寫,方便辨識他是一個靜態物件
Javascript的靜態物件通常會設計成單件,用來管理某個區塊的功能或是設計成不帶有屬性的Utils工具類別
private屬性跟函數使用var宣告,public屬性跟函數使用”類別名稱.xxx”宣告

Example

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
// 避免覆蓋,也可以改成如果名字已經存在的話,拋出例外    
if (typeof (Handler) == 'undefined') {
Handler = {};
}

(function () {
// private的靜態屬性
var privateName = "David";

// public的靜態屬性
Handler.publicName = "David Chen";

// private的靜態函數
var privateFunction = function () {
return "private function";
};

// public的靜態函數
Handler.publicFunction = function () {
return "public function";
};

Handler.info = function () {
// 可以讀取內部private的attribute and function
console.info(privateName);

//這邊的this等同Handler物件, 所以透過this只能讀取public的attribute and function
console.info(this.publicName);
};
})();

console.info(privateName); // privateName is not defined
console.info(Handler.publicName); // David Chen
console.info(privateFunction()); // privateFunction is not defined
console.info(Handler.publicFunction()); // public function
Handler.info();