微信小程序?qū)崿F(xiàn)watch監(jiān)聽
Vue 提供了一種通用的方式來觀察和響應(yīng) Vue 實例上的數(shù)據(jù)變動:監(jiān)聽屬性 watch。
雖然watch的濫用會導(dǎo)致性能不佳,但在一些情況下我們還是需要watch,使得代碼更加簡潔、邏輯更加清晰(其實就是嫌麻煩...)。
小程序?qū)崿F(xiàn) 類似vue 一樣的watch 監(jiān)聽數(shù)據(jù)
將方法注冊到app.js 中也可以使用高級一點的寫法
使用裝飾器模式將小程序page 重寫掛在到生命周期函數(shù)上或者掛在頁面this 上每次就不需要重新在調(diào)用初始化一次。本文對裝飾器模式不做介紹這是個思路。等待下次實現(xiàn)
setWatcher(page) {
let data = page.data; // 獲取page 頁面data
let watch = page.watch;
for(let i in watch){
let key = i.split('.'); // 將watch中的屬性以'.'切分成數(shù)組
let nowData = data; // 將data賦值給nowData
let lastKey = key[key.length - 1];
let watchFun = watch[i].handler || watch[i]; // 兼容帶handler和不帶handler的兩種寫法
let deep = watch[i].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) {
let val = obj[key];
// 判斷deep是true 且 val不能為空 且 typeof val==='object'(數(shù)組內(nèi)數(shù)值變化也需要深度監(jiān)聽)
if (deep && val != null && typeof val === 'object') {
for(let i in val){
this.observe(val, i, watchFun, deep, page); // 遞歸調(diào)用監(jiān)聽函數(shù)
}
}
let 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;
}
})
}
頁面使用:
onLoad: function () {
app.setWatcher(this);
setTimeout(()=>{
this.setData({
name:"kangbosodoa"
})
},2000)
},
watch: {
name: {
handler(newValue,oldvalue) {
console.log(this)
console.log(newValue,oldvalue,"變化了");
},
deep: true
},
type:{
handler(newValue) {
console.log(newValue,"屬性發(fā)生變化");
},
deep: true // 是否深度監(jiān)聽
}
},
到此這篇關(guān)于微信小程序?qū)崿F(xiàn)watch監(jiān)聽的文章就介紹到這了,更多相關(guān)小程序watch監(jiān)聽內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
使用Webpack構(gòu)建多頁面程序的實現(xiàn)步驟
這篇文章主要介紹了使用Webpack構(gòu)建多頁面程序的實現(xiàn)步驟,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-03-03
圖片輪換效果實現(xiàn)代碼(點擊按鈕停止執(zhí)行)
在這個實例中需要注意的是,要把images文件夾下圖片的命名設(shè)置為有順序的,1、2、3..才可以,感興趣的朋友可以參考下2013-04-04
JS實現(xiàn)iframe自適應(yīng)高度的方法示例
這篇文章主要介紹了JS實現(xiàn)iframe自適應(yīng)高度的方法,結(jié)合實例形式分析了JS實現(xiàn)iframe高度自適應(yīng)的實現(xiàn)技巧,并給出了項目示例供大家參考,需要的朋友可以參考下2017-01-01
詳解JavaScript到TypeScript的轉(zhuǎn)換過程
JavaScript是一門強大而靈活的編程語言,TypeScript作為JavaScript的超集,為開發(fā)人員提供了靜態(tài)類型檢查、更好的協(xié)作能力和面向?qū)ο缶幊痰闹С?,本文將詳細講解如何將JavaScript代碼轉(zhuǎn)換為TypeScript,并寫一些代碼示例參考2023-06-06
JavaScript使用SpreadJS創(chuàng)建Excel查看器
在現(xiàn)代的Web應(yīng)用開發(fā)中,Excel文件的處理和展示是一項常見的需求,小編今天將為大家展示如何借助SpreadJS來創(chuàng)建一個Excel查看器,感興趣的小伙伴可以了解下2023-12-12
JS防抖節(jié)流函數(shù)的實現(xiàn)與使用場景
在行走江湖的過程中,會出現(xiàn)很多性能優(yōu)化的問題來讓你手足無措,那么這篇文章主要給大家介紹了關(guān)于JS防抖節(jié)流函數(shù)的實現(xiàn)與使用場景,針對這兩個問題來為你答疑解惑,需要的朋友可以參考下2021-07-07

