The applet listens for field changes

Monitor globalData parameter changes

//app.js
App({
  onLaunch: function () {
    let that = this
    // 在这里用定时器模拟网络请求的过程
    setTimeout(function(){
      that.globalData.userInfo= 'pxh'
    },3000) 
  },
 // 这里这么写,是要在其他界面监听,而不是在app.js中监听,而且这个监听方法,需要一个回调方法。
  watch:function(method){
    var obj = this.globalData; 
    let userInfo = globalData.userInfo
    Object.defineProperty(obj,"userInfo", {
      configurable: true,
      enumerable: true,
      set: function (value) {
        userInfo = value // 实践下来全局这里要复制,不然会变为null,同时要在外面定义好在复制,不然赋不上
        method(value);
      },
      get:function(){
      // 可以在这里打印一些东西,然后在其他界面调用getApp().globalData.name的时候,这里就会执行。
        return userInfo 
      }
    })
  },
  globalData: {
    userInfo: null
  }
})


// 然后在index.js中的声明周期中实现
onLoad: function (options) {
  let that = this;
  getApp().watch(that.watchBack)
},
watchBack: function (name){
  console.log('this.name==' + name)
}

Listen for changes in custom component fields

observers: {
  'addressText': function (val1, val2) {
   	 console.log(11111)
  }
},

Guess you like

Origin blog.csdn.net/qq_43384836/article/details/130949829