钉钉小程序中如何监听全局变量

在开发钉钉小程序的过程中遇到的问题,需要监听到全局变量的改变后去做一些操作,百度上参考了很多微信小程序的监听方式,基本是相通的能够直接使用,挂上参考链接:小程序如何在其他页面监听globalData中值的变化?

文中写到,由于要监听到globalData中的值的变化,所以一般要在globalData改变时回调一个方法。
例如监听一个name属性

//app.js
App({
  onLaunch: function () {
    let that = this
    // 在这里用定时器模拟网络请求的过程
    setTimeout(function(){
      that.globalData.name = 'pxh'
    },3000) 
  },
 // 这里这么写,是要在其他界面监听,而不是在app.js中监听,而且这个监听方法,需要一个回调方法。
  watch: function(method, page) {
    var obj = this.globalData;
    Object.defineProperty(obj,"name", {
      configurable: true,
      enumerable: true,
      set: function (value) {
        this._name = value;
        console.log('是否会被执行')
        method(value, page);
      },
      get:function(){
      // 可以在这里打印一些东西,然后在其他界面调用getApp().globalData.name的时候,这里就会执行。
        return this._name
      }
    })
  },
  globalData: {
    name:'msr'
  }
})
 
 
// 然后在index.js中的声明周期中实现
onLoad: function (options) {
  let that = this;
  // 将当前页面实例也作为一个参数传过去,否则无法使用
  getApp().watch(that.watchBack, that)
},
watchBack: function (name, page) {
  console.log(page)
  console.log('全局name值改变' + name)
}

在参考案例当中是没有 page 这个参数的,因为在实际用到的情况下发现监听到全局变量改变后,没法获取到当前页面的实例 ,所以在最开始初始化的时候就把实例当成一个参数传递了,在回调的时候再拿回来就能使用了。

你可能感兴趣的:(钉钉小程序)