微信小程序 - 如何监听globalData 变量的变化

最新发现

这个才是真正的解决办法啊!

一、app.js中定义watch函数

onLaunch() {
   // ...
},
watch:function(method){
    var obj = this.globalData;
    Object.defineProperty(obj,"hasToken", {
      configurable: true,
      enumerable: true,
      set: function (value) {
        this._hasToken = value;
        console.log('是否会被执行2')
        method(value);
      },
      get:function(){
        // 可以在这里打印一些东西,然后在其他界面调用getApp().globalData.name的时候,这里就会执行。
        return this._hasToken
      }
    })
},
globalData: {
  hasToken:false
}

二、在需要监听变量的js中使用

我这里是在一个组件中,需要根据是否登录的状态,来进行请求

Component({
  lifetimes:{
  	attached(){
  		let self = this;
  		app.watch(self.watchBack.bind(self)); 
  		// 注意:watchBack后面要重新绑定this,否则下边的this.queryPreset()找不到
  	}
  },
  methods:{
  	watchBack(hasToken){
      if(!hasToken) return;
      this.queryPreset();
    },
  }
})

参考文章:https://www.jb51.net/article/165365.htm
参考文章(监听多个属性):https://www.cnblogs.com/dream-saddle/p/11180053.html

评论 2
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值