【微信小程序-原生开发】watch 的实现

微信小程序-原生开发本身并没有 vue 中 watch 的功能,可以通过以下方式实现

定义监听器

utils\watch.js

/**
 * 设置监听器
 */
export function setWatcher(page) {
    
    
  let data = page.data;
  let watch = page.watch;
  Object.keys(watch).forEach(v => {
    
    
      let key = v.split('.'); // 将watch中的属性以'.'切分成数组
      let nowData = data; // 将data赋值给nowData
      for (let i = 0; i < key.length - 1; i++) {
    
     // 遍历key数组的元素,除了最后一个!
          nowData = nowData[key[i]]; // 将nowData指向它的key属性对象
      }
      let lastKey = key[key.length - 1];
      let watchFun = watch[v].handler || watch[v]; // 兼容带handler和不带handler的两种写法
      let deep = watch[v].deep; // 若未设置deep,则为undefine
      observe(nowData, lastKey, watchFun, deep, page); // 监听nowData对象的lastKey
  })
}
/**
* 监听属性 并执行监听函数
*/
function observe(obj, key, watchFun, deep, page) {
    
    
  var val = obj[key];
  // 判断deep是true 且 val不能为空 且 typeof val==='object'(数组内数值变化也需要深度监听)
  if (deep && val != null && typeof val === 'object') {
    
    
      Object.keys(val).forEach(childKey => {
    
     // 遍历val对象下的每一个key
          observe(val, childKey, watchFun, deep, page); // 递归调用监听函数
      })
  }
  Object.defineProperty(obj, key, {
    
    
      configurable: true,
      enumerable: true,
      set: function(newVal) {
    
    
          watchFun.call(page, newVal, val); 
          val = newVal;
          if (deep) {
    
     // 若是深度监听,重新监听该对象,以便监听其属性。
              observe(obj, key, watchFun, deep, page);
          }
      },
      get: function() {
    
    
          return val;
      }
  })
}
module.exports = {
    
    
  setWatcher: setWatcher
}

导入监听器

注意修改相对路径

import {
    
    
  setWatcher
} from '../../../../utils/watch.js'

启动监听器

在页面的生命周期 onLoad 中

  onLoad() {
    
    
    setWatcher(this)
  }

使用监听器

此时便可像 vue 中一样,使用 watch 啦!

  watch: {
    
    
    //监控对象
    placeInfo: {
    
    
      handler(val) {
    
    
        let child = this.selectComponent('.infoForm');
        child.setData({
    
    
          "userInfo.placeInfo": val
        })
      },
      deep: true
    }
  },

猜你喜欢

转载自blog.csdn.net/weixin_41192489/article/details/129397230