對象的getter與setter

在ES5以前,讀/寫對象的屬性時倾哺,產生的結果就是返回了對象屬性的值/設置了對象屬性的值轧邪。
在ES5之后刽脖,對于用get/set方法定義的屬性來說,對它進行讀/寫屬性時忌愚,其結果卻是可以由開發(fā)者來自定義的曲管。即給了開發(fā)者自己去定義“讀/寫對象的屬性”這個兩種操作的具體行為的權利,使得靈活性大大提高硕糊。

例如:

var obj={
     _name:"veb",
     get name(){
             console.log("你獲取了name的值")院水;
             return this._name;
     },
     set name(a){
             console.log("你設置了name的值為"+a);
             return this._name=a;
     },
}
console.log(obj.name)//你獲取了name的值
obj.name="len"http://你設置了name的值為len

聰明的你馬上就能想到vue的雙向綁定简十,這是為師對你的信任檬某!


對于get和set不過是一個es5提供的語法糖而已,為什么這么說螟蝙?

一個對象恢恼,如果在你修改或獲取屬性值之前想做一些事情該怎么辦呢?


var o = (function(){
          var age = 0;
          return {
                  get_age:function(){
                        console.log("你想知道我的年齡胰默?已經(jīng)給你return出去了")
                        return age;
                  },
                  set_age:function(v){
                       console.log("你要設置我的年齡為"+v)
                       age=v;
                 }
             }
         })();
     o.get_age();//你想知道我的年齡场斑?已經(jīng)給你return出去了
     o.set_age(12);//你要設置我的年齡為12
     console.log(o.get_age());//你想知道我的年齡?已經(jīng)給你return出去了      12


現(xiàn)在明白了吧牵署?vue的數(shù)據(jù)檢測就是使用的es5 的get&set不同于angular臟查詢機制,那么如何批量檢測呢漏隐?

Object.defineProperty(obj,key碟刺,valueObj)

其中obj代表要在哪個對象上設置屬性锁保,key為屬性名,valueObj為值對象配置半沽,相關可以參考es5數(shù)組及對象處理方法

基礎用法
var obj={};
Object.defineProperty(obj,'age', {
            value: 18,
            writable: true,
            enumerable: true,
            configurable: true
 });
console.log(obj.age)//18爽柒;

//或者同時定義多個屬性:
Object.defineProperties(obj, {
            'age': {
                value: 24,
                writable: true,
                enumerable: true,
                configurable: true
            },
            'sex': {
                value: '男',
                writable: false,
                enumerable: false,
                configurable: false
            }
});
定義get&set
var obj={
      _name:"veb"
};
Object.defineProperty(obj,"name", {
           get: function() {
             console.log("你獲取了name的值");
             return this._name;
           },
           set: function(y) {
             console.log("你設置了的值")
             return this._name=y;
           },
});

注意:key和要監(jiān)測的屬性名不能為同一個,不然同時使用get&set會出現(xiàn)死循環(huán)者填!

批量監(jiān)測:
function fun(obj){
        var obj2={};
        for(var i in obj){
            this["_"+i]=obj[i];
        }
        console.log(this);
        var self=this;
        for(var x in this){
            (function(x){
                Object.defineProperty(self,x.replace("_",""), {
                    get: function() {
                        console.log("你獲取了"+x+"的值")
                        return self[x]
                    },
                    enumerable: true,
                    configurable: true,
                    set: function(y) {
                        console.log("你設置了"+x+"的值")
                        return self[x]=y;
                    },
                });
            })(x)
        }
    }
    var person=new fun({
        name:"veb",
        age:"20"
    })
    console.log(person.name)//你獲取了name的值       veb
    person.age=50//你設置了age的值

加油浩村!歡迎光臨個人站清風筆記

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市占哟,隨后出現(xiàn)的幾起案子心墅,更是在濱河造成了極大的恐慌,老刑警劉巖榨乎,帶你破解...
    沈念sama閱讀 221,635評論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件怎燥,死亡現(xiàn)場離奇詭異,居然都是意外死亡蜜暑,警方通過查閱死者的電腦和手機铐姚,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,543評論 3 399
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來肛捍,“玉大人隐绵,你說我怎么就攤上這事之众。” “怎么了依许?”我有些...
    開封第一講書人閱讀 168,083評論 0 360
  • 文/不壞的土叔 我叫張陵棺禾,是天一觀的道長。 經(jīng)常有香客問我峭跳,道長膘婶,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 59,640評論 1 296
  • 正文 為了忘掉前任坦康,我火速辦了婚禮竣付,結果婚禮上,老公的妹妹穿的比我還像新娘滞欠。我一直安慰自己古胆,他們只是感情好,可當我...
    茶點故事閱讀 68,640評論 6 397
  • 文/花漫 我一把揭開白布筛璧。 她就那樣靜靜地躺著逸绎,像睡著了一般。 火紅的嫁衣襯著肌膚如雪夭谤。 梳的紋絲不亂的頭發(fā)上棺牧,一...
    開封第一講書人閱讀 52,262評論 1 308
  • 那天,我揣著相機與錄音朗儒,去河邊找鬼颊乘。 笑死,一個胖子當著我的面吹牛醉锄,可吹牛的內容都是我干的乏悄。 我是一名探鬼主播,決...
    沈念sama閱讀 40,833評論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼恳不,長吁一口氣:“原來是場噩夢啊……” “哼檩小!你這毒婦竟也來了?” 一聲冷哼從身側響起烟勋,我...
    開封第一講書人閱讀 39,736評論 0 276
  • 序言:老撾萬榮一對情侶失蹤规求,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后卵惦,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體阻肿,經(jīng)...
    沈念sama閱讀 46,280評論 1 319
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 38,369評論 3 340
  • 正文 我和宋清朗相戀三年沮尿,在試婚紗的時候發(fā)現(xiàn)自己被綠了丛塌。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 40,503評論 1 352
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖姨伤,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情庸疾,我是刑警寧澤乍楚,帶...
    沈念sama閱讀 36,185評論 5 350
  • 正文 年R本政府宣布,位于F島的核電站届慈,受9級特大地震影響徒溪,放射性物質發(fā)生泄漏。R本人自食惡果不足惜金顿,卻給世界環(huán)境...
    茶點故事閱讀 41,870評論 3 333
  • 文/蒙蒙 一臊泌、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧揍拆,春花似錦渠概、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,340評論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至筒狠,卻和暖如春猪狈,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背辩恼。 一陣腳步聲響...
    開封第一講書人閱讀 33,460評論 1 272
  • 我被黑心中介騙來泰國打工雇庙, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人灶伊。 一個月前我還...
    沈念sama閱讀 48,909評論 3 376
  • 正文 我出身青樓疆前,卻偏偏與公主長得像,于是被迫代替她去往敵國和親谁帕。 傳聞我的和親對象是個殘疾皇子峡继,可洞房花燭夜當晚...
    茶點故事閱讀 45,512評論 2 359

推薦閱讀更多精彩內容

  • 國家電網(wǎng)公司企業(yè)標準(Q/GDW)- 面向對象的用電信息數(shù)據(jù)交換協(xié)議 - 報批稿:20170802 前言: 排版 ...
    庭說閱讀 11,005評論 6 13
  • 1. Java基礎部分 基礎部分的順序:基本語法,類相關的語法匈挖,內部類的語法碾牌,繼承相關的語法,異常的語法儡循,線程的語...
    子非魚_t_閱讀 31,663評論 18 399
  • 函數(shù)和對象 1舶吗、函數(shù) 1.1 函數(shù)概述 函數(shù)對于任何一門語言來說都是核心的概念。通過函數(shù)可以封裝任意多條語句择膝,而且...
    道無虛閱讀 4,581評論 0 5
  • 臨摹自@宸呦呦 十分不像誓琼,三分像 要努力的還很多 長路漫漫,堅持為重
    覃格爾閱讀 211評論 7 9
  • 1 今年的梧桐花如約開放了,一串一串的腹侣,像掛滿了無數(shù)的風鈴叔收,在風中搖曳。淡淡的紫傲隶,淡淡的香饺律。林蕭站在梧桐樹下,看著...
    暮雪紛紛閱讀 806評論 7 10