JS 如何监听一个变量的变化

基于get 和 set

var a = { watchValue:0 };
var lastTimeValue=a.watchValue;
Object.defineProperty(a, 'watchValue', {
  get: function() {
    console.log('get:' + watchValue);
    return watchValue;
  },
  set: function(value) {
    watchValue = value;
    if(lastTimeValue!=watchValue){
        lastTimeValue=watchValue;
        console.log('value changed!! set: ' + watchValue);
    }
  }
});

结果如下:

a.watchValue = 2; // value changed!! set: 2
console.log(a.watchValue);// get:2

posted @ 2018-09-28 17:01  jim520  阅读(23872)  评论(0编辑  收藏  举报