JavaScript缺少塊級範圍,沒有private修飾符,但它具有函數範圍。範圍的好處是內建函式可以訪問它們的外部函數的參數和變數(除了this和argument。內部中的函數中的this指向全域對象,argument指向內建函式的函數參數)。我們可以利用這種屬性來類比物件導向中的私人屬性。
複製代碼 代碼如下:var myObject=function(value){
var value=value || 0;
return{
increment:function(num){
value+=typeof num==='number' ? num : 0;
},
setValue:function(num){
value = typeof num==='number' ? num : value;
},
getValue:function(){
return value;
}
}
}(10)
//alert(myObject.getValue()); //10
myObject.setValue(20);
//alert(myObject.getValue()); //20
myObject.increment(5);
alert(myObject.getValue()); //25
如上例中,myObjeact是匿名函數執行後返回的對象。匿名函數中變數value對於匿名函數外部來說是不可訪問的,但對於其內部的函數,是可以訪問的,匿名函數執行結束,由於變數value仍被返回的myObject對象所存取,故value所佔據的記憶體並沒有被銷毀。此時,內部的變數value就如同myObject對象的私人變數一樣。 複製代碼 代碼如下:var myObject=function(value){
var name='MyObject';
return{
increment:function(num){
value+=typeof num==='number' ? num : 0;
},
setValue:function(num){
value = typeof num==='number' ? num : value;
},
getValue:function(){
//alert(this);
return value;
},
getName:function(){
return name;
},
setName:function(nameStr){
name=nameStr;
},
toString:function(){
return '[Object:'+name+']';
}
}
}
var obj=myObject(5);
obj.increment(6);
//alert(obj.getValue()); // 11
//alert(obj); //[Object:MyObject]
obj.setName('temp object 01');
alert(obj) //[Object:temp object 01]