標籤:javascript 文法 屬性 私人 語言
javaScript並沒有特殊的文法來表示私人、保護、或公用屬性和方法,在這一點上與
java或其他語言是不同的,JavaScript中所有對象的成員是公用的:
var myobj={
mypop:1,
getProp:function(){
return this.myprop;
}
};
console.log(myobj.myprop); // ‘myprop’是公有可訪問的
console.log(myobj.getProp()); //getProp()也是公有的,可訪問的
當使用建構函式建立對象時也同樣如此,即所有的成員仍然都是公用的。
function Gadget(){
this.name=’iPod’;
this.stretch =function(){
return ‘iPad’;
};
}
var toy = new Gadget();
console.log(toy.name); //name是公有的
console.log(toy.stretch()); //stretch()是公有的
雖然javaScript語言中並沒有用於私人成員的特殊文法,但是可以使用閉包來實現這種
功能。建構函式建立了一個閉包,而在閉包範圍內部的任意變數都不會暴露給建構函式
以外的代碼。然而,這些私人變數仍然可以用於公用方法中;即定義在建構函式中,且
作為返回對象的一個部分暴露給外部的方法。
如下面樣本:
function Gadget(){
//私人變數
var name =’iPod’;
//公有函數
this.getName = function(){
return name;
} ;
}
var toy = new Gadget();
//name是undefined的,是私人的
console.log(toy.name);
//公有方法訪問
console.log(toy.getName()); //輸出Ipod
如上面例子,很容易在Javascript實現私人性。需要做的只是在函數中將需要保持為私人屬性的資料封裝起來,並確保它對函數來說是局部變數,這意味著外部函數不能訪問它
javaScript中私人屬性和方法