当前位置:   article > 正文

微信小程序实现页面数据侦听器,类似vue的watch_微信小程序如何监听数据变化

微信小程序如何监听数据变化

既然小程序的组件已经有Observer功能,那为什么还要手写watch功能呢?

  1. Observer只能在Component中使用,没法在Page中使用。若是想在Page中监控某一数据的变化,Observer做不到。
  2. Observer属于小程序的新功能,只能在高版本微信使用,低版本微信无法使用。公司的小程序就因为使用了Observer功能,导致很多低版本微信用户无法使用这个小程序。

 HTML代码

  1. <view>{{n1}}+{{n2}}={{sum}}</view>
  2. <button bindtap="addn1">页面中监听n1+1</button>
  3. <button bindtap="addn2">页面中监听n2+1</button>

新建一个watch.js文件存放监听器的逻辑函数,代码如下:

  1. /**
  2. * 设置监听器
  3. */
  4. export function setWatcher(page) {
  5. let data = page.data;
  6. let watch = page.watch;
  7. Object.keys(watch).forEach(v => {
  8. let key = v.split('.'); // 将watch中的属性以'.'切分成数组
  9. let nowData = data; // 将data赋值给nowData
  10. for (let i = 0; i < key.length - 1; i++) { // 遍历key数组的元素,除了最后一个!
  11. nowData = nowData[key[i]]; // 将nowData指向它的key属性对象
  12. }
  13. let lastKey = key[key.length - 1];
  14. let watchFun = watch[v].handler || watch[v]; // 兼容带handler和不带handler的两种写法
  15. let deep = watch[v].deep; // 若未设置deep,则为undefine
  16. observe(nowData, lastKey, watchFun, deep, page); // 监听nowData对象的lastKey
  17. })
  18. }
  19. /**
  20. * 监听属性 并执行监听函数
  21. */
  22. function observe(obj, key, watchFun, deep, page) {
  23. var val = obj[key];
  24. // 判断deep是true 且 val不能为空 且 typeof val==='object'(数组内数值变化也需要深度监听)
  25. if (deep && val != null && typeof val === 'object') {
  26. Object.keys(val).forEach(childKey => { // 遍历val对象下的每一个key
  27. observe(val, childKey, watchFun, deep, page); // 递归调用监听函数
  28. })
  29. }
  30. Object.defineProperty(obj, key, {
  31. configurable: true,
  32. enumerable: true,
  33. set: function(newVal) {
  34. watchFun.call(page, newVal, val);
  35. val = newVal;
  36. if (deep) { // 若是深度监听,重新监听该对象,以便监听其属性。
  37. observe(obj, key, watchFun, deep, page);
  38. }
  39. },
  40. get: function() {
  41. return val;
  42. }
  43. })
  44. }
  45. module.exports = {
  46. setWatcher: setWatcher
  47. }

 在该文件中引入watch.js,

   tips:如果有多个页面都需要使用watch监听,可以直接在app.js中引入该文件,注册成全局函数,这样就不用每个文件都去引入watch.js了,只需要在使用的页面onLoad的时候调用一次该函数,就能愉快的使用watch了。

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

 js代码

  1. data: {
  2. n1:1,
  3. n2:0,
  4. sum:0,
  5. obj: {},
  6. },
  7. addn1(){
  8. this.setData({
  9. n1:this.data.n1+1,
  10. })
  11. },
  12. addn2(){
  13. this.setData({
  14. n2:this.data.n2+1,
  15. })
  16. },
  17. onLoad(options) {
  18. // 在onload的时候调用一次监听函数,然后就可以像vue一样愉快的使用watch了
  19. setWatcher(this);
  20. },
  21. // 用法完全和vue一样,也能实现对象的深度监听
  22. watch: {
  23. n1(n1) {
  24. console.log(n1)
  25. this.setData({
  26. sum:n1+this.data.n2
  27. })
  28. },
  29. n2(n2) {
  30. console.log(n2)
  31. this.setData({
  32. sum:n2+this.data.n1
  33. })
  34. },
  35. obj: {
  36. handler(v) {
  37. console.log(v)
  38. },
  39. deep: true
  40. }
  41. },

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/很楠不爱3/article/detail/123830
推荐阅读
相关标签
  

闽ICP备14008679号