網(wǎng)絡(luò)之美 JavaScript中Get和Set訪問(wèn)器的實(shí)現(xiàn)代碼
function Field(val){
this.value = val;
}
Field.prototype = {
get value(){
return this._value;
},
set value(val){
this._value = val;
}
};
var field = new Field("test");
field.value="test2";
//field.value will now return "test2"
在如下瀏覽器能正常工作:

我們常用的實(shí)現(xiàn)方法可能是這樣的:
function Field(val){
var value = val;
this.getValue = function(){
return value;
};
this.setValue = function(val){
value = val;
};
}
var field = new Field("test");
field.setValue("test2")
field.getValue() // return "test2"
在DOM元素上Get和Set訪問(wèn)器的實(shí)現(xiàn)
HTMLElement.prototype.__defineGetter__("description", function () {
return this.desc;
});
HTMLElement.prototype.__defineSetter__("description", function (val) {
this.desc = val;
});
document.body.description = "Beautiful body";
// document.body.description will now return "Beautiful body";
在如下瀏覽器能正常工作:

通過(guò)Object.defineProperty實(shí)現(xiàn)訪問(wèn)器
將來(lái)ECMAScript標(biāo)準(zhǔn)的擴(kuò)展對(duì)象的方法會(huì)通過(guò)Object.defineProperty來(lái)實(shí)現(xiàn),這也是為什么IE8就是通過(guò)這種方法來(lái)實(shí)現(xiàn)get和set訪問(wèn)器,看來(lái)微軟還是很有遠(yuǎn)見(jiàn)的,遺憾的是目前只有IE8+和Chrome 5.0+支持,其它的瀏覽器都不支持,而且IE8+也只支持DOM元素,不過(guò)將來(lái)的版本將和Chrome一樣支持普通的Javascript對(duì)象。
DOM元素上的Get和Set訪問(wèn)器的實(shí)現(xiàn)
Object.defineProperty(document.body, "description", {
get : function () {
return this.desc;
},
set : function (val) {
this.desc = val;
}
});
document.body.description = "Content container";
// document.body.description will now return "Content container"
在如下瀏覽器能正常工作:

var lost = {
loc : "Island"
};
Object.defineProperty(lost, "location", {
get : function () {
return this.loc;
},
set : function (val) {
this.loc = val;
}
});
lost.location = "Another island";
// lost.location will now return "Another island"
在如下瀏覽器能正常工作:

本文總結(jié)
盡管微軟的IE只是支持了Object.defineProperty,沒(méi)有完美的實(shí)現(xiàn)Get和Set訪問(wèn)器,但是我們已經(jīng)看到了IE有了很大的進(jìn)步,特別是剛發(fā)布的IE9使用的新的javascript引擎,支持HTML5和CSS3,支持硬件加速等等,相信有一天各個(gè)瀏覽器都能完全擁抱標(biāo)準(zhǔn),帶來(lái)一個(gè)完美的WEB世界。
參考文獻(xiàn):
1. Getters and setters with JavaScript
2. JavaScript Getters and Setters
作者:夢(mèng)想
- JS的get和set使用示例
- 探討:JavaScript ECAMScript5 新特性之get/set訪問(wèn)器
- ES6 javascript中class類的get與set用法實(shí)例分析
- js 字符串操作函數(shù)
- 告訴你什么是javascript的回調(diào)函數(shù)
- js中匿名函數(shù)的N種寫法
- js中回調(diào)函數(shù)的學(xué)習(xí)筆記
- JavaScript函數(shù)的4種調(diào)用方法詳解
- JavaScript構(gòu)造函數(shù)詳解
- 顯示js對(duì)象所有屬性和方法的函數(shù)
- JavaScript中set與get方法用法示例
相關(guān)文章
event對(duì)象獲取方法總結(jié)在google瀏覽器下測(cè)試
Event 對(duì)象代表事件的狀態(tài),比如事件在其中發(fā)生的元素、鍵盤按鍵的狀態(tài)、鼠標(biāo)的位置、鼠標(biāo)按鈕的狀態(tài),Event對(duì)象的獲取方法如下,感興趣的朋友可以參考下2013-11-11
JavaScript簡(jiǎn)單獲取系統(tǒng)當(dāng)前時(shí)間完整示例
這篇文章主要介紹了JavaScript簡(jiǎn)單獲取系統(tǒng)當(dāng)前時(shí)間的方法,涉及javascript針對(duì)日期與時(shí)間的判斷以及字符串組合的相關(guān)技巧,需要的朋友可以參考下2016-08-08
IE event.srcElement和FF event.target 功能比較
可以捕獲當(dāng)前事件作用的對(duì)象,如event.srcElement.tagName可以捕獲活動(dòng)標(biāo)記名稱。2010-03-03
uniapp小程序配置tabbar底部導(dǎo)航欄實(shí)戰(zhàn)指南
tabBar如果應(yīng)用是一個(gè)多tab應(yīng)用,可以通過(guò)tabBar配置項(xiàng)指定tab欄的表現(xiàn),以及tab切換時(shí)顯示的對(duì)應(yīng)頁(yè),下面這篇文章主要給大家介紹了關(guān)于uniapp小程序配置tabbar底部導(dǎo)航欄的相關(guān)資料,需要的朋友可以參考下2022-09-09
layer擴(kuò)展打開(kāi)/關(guān)閉動(dòng)畫的方法
今天小編就為大家分享一篇layer擴(kuò)展打開(kāi)/關(guān)閉動(dòng)畫的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-09-09
js數(shù)值和和字符串進(jìn)行轉(zhuǎn)換時(shí)可以對(duì)不同進(jìn)制進(jìn)行操作
這篇文章主要介紹了js數(shù)值和和字符串進(jìn)行轉(zhuǎn)換時(shí)可以對(duì)不同進(jìn)制進(jìn)行操作,需要的朋友可以參考下2014-03-03
mysql輸出數(shù)據(jù)賦給js變量報(bào)unterminated string literal錯(cuò)誤原因
mysql 數(shù)據(jù)庫(kù)數(shù)據(jù)賦給js變量報(bào)unterminated string literal錯(cuò)誤原因2010-05-05
js實(shí)現(xiàn)簡(jiǎn)單計(jì)算器
一個(gè)簡(jiǎn)潔的網(wǎng)頁(yè)JS計(jì)算器,附詳細(xì)代碼釋義。通過(guò)下邊的效果演示就可以看到,這是一個(gè)挺小的js網(wǎng)頁(yè)計(jì)算器,界面美化的我想還是不錯(cuò)的,畢竟在沒(méi)有使用任何圖片修飾的情況下,很好看,而且功能挺實(shí)用,可以完成基本的數(shù)學(xué)算數(shù)運(yùn)算。2015-11-11
js動(dòng)畫(animate)簡(jiǎn)單引擎代碼示例
仿照f(shuō)lash的動(dòng)畫原理,自己寫了一個(gè)非常簡(jiǎn)單的js動(dòng)畫引擎。2012-12-12

