js 實(shí)現(xiàn)watch監(jiān)聽數(shù)據(jù)變化的代碼
1.js
/**
* @desc 屬性改變監(jiān)聽,屬性被set時出發(fā)watch的方法,類似vue的watch
* @author Jason
* @study https://www.jianshu.com/p/00502d10ea95
* @data 2018-04-27
* @constructor
* @param {object} opts - 構(gòu)造參數(shù). @default {data:{},watch:{}};
* @argument {object} data - 要綁定的屬性
* @argument {object} watch - 要監(jiān)聽的屬性的回調(diào)
* watch @callback (newVal,oldVal) - 新值與舊值
*/
class watcher{
constructor(opts){
this.$data = this.getBaseType(opts.data) === 'Object' ? opts.data : {};
this.$watch = this.getBaseType(opts.watch) === 'Object' ? opts.watch : {};
for(let key in opts.data){
this.setData(key)
}
}
getBaseType(target) {
const typeStr = Object.prototype.toString.apply(target);
return typeStr.slice(8, -1);
}
setData(_key){
Object.defineProperty(this,_key,{
get: function () {
return this.$data[_key];
},
set : function (val) {
const oldVal = this.$data[_key];
if(oldVal === val)return val;
this.$data[_key] = val;
this.$watch[_key] && typeof this.$watch[_key] === 'function' && (
this.$watch[_key].call(this,val,oldVal)
);
return val;
},
});
}
}
// export default watcher;
2.html
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<title>wathc</title>
</head>
<body>
<script src="./watch.js"></script>
<script>
let wm = new watcher({
data:{
a: 0,
b: 'hello'
},
watch:{
a(newVal,oldVal){
console.log(newVal, oldVal); // 111 0
}
}
})
wm.a = 111
</script>
</body>
</html>
3. 給vm.a 從新賦值 就能看到 newVal 和oldVal的變化
總結(jié)
以上所述是小編給大家介紹的js 實(shí)現(xiàn)watch監(jiān)聽數(shù)據(jù)變化的代碼,希望對大家有所幫助,如果大家有任何疑問歡迎給我留言,小編會及時回復(fù)大家的!
- JS如何監(jiān)聽div的resize事件詳解
- JavaScript 監(jiān)聽組合按鍵思路及代碼實(shí)現(xiàn)
- JavaScript如何實(shí)現(xiàn)監(jiān)聽鍵盤輸入和鼠標(biāo)監(jiān)點(diǎn)擊
- NodeJS多種創(chuàng)建WebSocket監(jiān)聽的方式(三種)
- js實(shí)現(xiàn)無刷新監(jiān)聽URL的變化示例代碼詳解
- JavaScript監(jiān)聽鍵盤事件代碼實(shí)現(xiàn)
- 使用JS監(jiān)聽鍵盤按下事件(keydown event)
- javascript事件監(jiān)聽與事件委托實(shí)例詳解
- 如何用JS實(shí)現(xiàn)簡單的數(shù)據(jù)監(jiān)聽
相關(guān)文章
JavaScript中Object.values()的用法舉例
這篇文章主要給大家介紹了關(guān)于JavaScript中Object.values()的用法舉例,Object.values()是JavaScript中一個內(nèi)置的靜態(tài)函數(shù),用于返回一個對象中所有屬性值的數(shù)組,需要的朋友可以參考下2023-09-09
canvas實(shí)現(xiàn)環(huán)形進(jìn)度條效果
本文主要介紹了canvas實(shí)現(xiàn)環(huán)形進(jìn)度條效果的實(shí)例。具有很好的參考價(jià)值。下面跟著小編一起來看下吧2017-03-03
layui點(diǎn)擊數(shù)據(jù)表格添加或刪除一行的例子
Js模塊打包exports require import的用法和區(qū)別
JavaScript強(qiáng)制類型轉(zhuǎn)換和隱式類型轉(zhuǎn)換操作示例
JavaScript中運(yùn)算符規(guī)則和隱式類型轉(zhuǎn)換示例詳解

