微信小程序?qū)崿F(xiàn)watch屬性監(jiān)聽數(shù)據(jù)變化

參考文檔:https://blog.csdn.net/xuyangxinlei/article/details/81408200

? 監(jiān)聽器的原理,將data中需監(jiān)聽的屬性寫在watch對象中,并給其提供一個方法凌简,當(dāng)被監(jiān)聽屬性的值改變時惕鼓,調(diào)用該方法蓬衡。所以很顯然唇礁,我們需要用到Javascript中的Object.defineProperty()方法碎捺,來手動劫持對象的getter/setter路鹰,從而實現(xiàn)給對象賦值時(調(diào)用setter)贷洲,執(zhí)行watch對象中相對應(yīng)的函數(shù),達(dá)到監(jiān)聽效果晋柱。

? 首先优构,既然是微信小程序自定義watch屬性,我建議直接將代碼寫在app.js內(nèi)雁竞,需要使用的頁面直接onLoad()內(nèi)調(diào)用getApp().setWatch(...)即可钦椭。

一、監(jiān)聽器代碼:

? 為了能夠全局使用監(jiān)聽器碑诉,我們需要在 app.js 中添加該方法(或者外部引入)

 /**
     * 設(shè)置監(jiān)聽器
     */
setWatcher(page) {
    let data = page.data;
    let watch = page.watch;
    Object.keys(watch).forEach(v => {
        let key = v.split('.'); // 將watch中的屬性以'.'切分成數(shù)組
        let nowData = data; // 將data賦值給nowData
        for (let i = 0; i < key.length - 1; i++) { // 遍歷key數(shù)組的元素彪腔,除了最后一個!
            nowData = nowData[key[i]]; // 將nowData指向它的key屬性對象
        }
        let lastKey = key[key.length - 1];
        // 假設(shè)key==='my.name',此時nowData===data['my']===data.my,lastKey==='name'
        let watchFun = watch[v].handler || watch[v]; // 兼容帶handler和不帶handler的兩種寫法
        let deep = watch[v].deep; // 若未設(shè)置deep,則為undefine
        this.observe(nowData, lastKey, watchFun, deep, page); // 監(jiān)聽nowData對象的lastKey
    })
},
/**
* 監(jiān)聽屬性 并執(zhí)行監(jiān)聽函數(shù)
*/
observe(obj, key, watchFun, deep, page) {
    var val = obj[key];
    // 判斷deep是true 且 val不能為空 且 typeof val==='object'(數(shù)組內(nèi)數(shù)值變化也需要深度監(jiān)聽)
    if (deep && val != null && typeof val === 'object') { 
        Object.keys(val).forEach(childKey=>{ // 遍歷val對象下的每一個key
            this.observe(val,childKey,watchFun,deep,page); // 遞歸調(diào)用監(jiān)聽函數(shù)
        })
    }
    var that = this;
    Object.defineProperty(obj, key, {
        configurable: true,
        enumerable: true,
        set: function(value) {
            // 用page對象調(diào)用,改變函數(shù)內(nèi)this指向,以便this.data訪問data內(nèi)的屬性值
            watchFun.call(page,value,val); // value是新值进栽,val是舊值
            val = value;
            if(deep){ // 若是深度監(jiān)聽,重新監(jiān)聽該對象德挣,以便監(jiān)聽其屬性。
                that.observe(obj, key, watchFun, deep, page); 
            }
        },
        get: function() {
            return val;
        }
    })
}
二快毛、在需要監(jiān)聽的頁面引入使用監(jiān)聽器:
// 需要使用監(jiān)聽器的頁面
Page({
    data: {
        name:"xuyang"
    },
    onLoad(){
        getApp().setWatcher(this.data, this.watch); // 設(shè)置監(jiān)聽器
        this.setData({
            name:'lxm'
        })
    },
    watch:{
        name:function(newValue){
            console.log(newValue); // name改變時格嗅,調(diào)用該方法輸出新值。
        }
    }
})
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末唠帝,一起剝皮案震驚了整個濱河市吗浩,隨后出現(xiàn)的幾起案子没隘,更是在濱河造成了極大的恐慌,老刑警劉巖右蒲,帶你破解...
    沈念sama閱讀 219,366評論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件赶熟,死亡現(xiàn)場離奇詭異瑰妄,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)映砖,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,521評論 3 395
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來邑退,“玉大人,你說我怎么就攤上這事地技◎谄撸” “怎么了?”我有些...
    開封第一講書人閱讀 165,689評論 0 356
  • 文/不壞的土叔 我叫張陵莫矗,是天一觀的道長飒硅。 經(jīng)常有香客問我,道長三娩,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,925評論 1 295
  • 正文 為了忘掉前任雀监,我火速辦了婚禮,結(jié)果婚禮上伊诵,老公的妹妹穿的比我還像新娘回官。我一直安慰自己曹宴,他們只是感情好歉提,可當(dāng)我...
    茶點故事閱讀 67,942評論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著版扩,像睡著了一般。 火紅的嫁衣襯著肌膚如雪礁芦。 梳的紋絲不亂的頭發(fā)上悼尾,一...
    開封第一講書人閱讀 51,727評論 1 305
  • 那天,我揣著相機(jī)與錄音闺魏,去河邊找鬼。 笑死析桥,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的埋虹。 我是一名探鬼主播沮焕,決...
    沈念sama閱讀 40,447評論 3 420
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼峦树!你這毒婦竟也來了旦事?” 一聲冷哼從身側(cè)響起急灭,我...
    開封第一講書人閱讀 39,349評論 0 276
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎葬馋,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體蛋逾,經(jīng)...
    沈念sama閱讀 45,820評論 1 317
  • 正文 獨居荒郊野嶺守林人離奇死亡窗悯,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,990評論 3 337
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了蒋院。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 40,127評論 1 351
  • 序言:一個原本活蹦亂跳的男人離奇死亡姑丑,死狀恐怖辞友,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情称龙,我是刑警寧澤,帶...
    沈念sama閱讀 35,812評論 5 346
  • 正文 年R本政府宣布,位于F島的核電站躬厌,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏扛施。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,471評論 3 331
  • 文/蒙蒙 一匙奴、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧泼菌,春花似錦、人聲如沸哗伯。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,017評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至俩滥,卻和暖如春贺奠,著一層夾襖步出監(jiān)牢的瞬間霜旧,已是汗流浹背敞嗡。 一陣腳步聲響...
    開封第一講書人閱讀 33,142評論 1 272
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點兒被人妖公主榨干…… 1. 我叫王不留棱貌,地道東北人。 一個月前我還...
    沈念sama閱讀 48,388評論 3 373
  • 正文 我出身青樓婚脱,卻偏偏與公主長得像勺像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子吟宦,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 45,066評論 2 355

推薦閱讀更多精彩內(nèi)容