微信小程序在其他页面监听globalData中值的变化(转载)

由于要监听到globalData中的值的变化,所以一般要在globalData改变时回调一个方法。例如我们监听一个name属性,大致代码如下:

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


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

【版权声明】本博文著作权归作者所有,任何形式的转载都请联系作者获取授权并注明出处!

【重要说明】本文为本人的学习记录,论点和观点仅代表个人而不代表当时技术的真理,目的是自我学习和有幸成为可以向他人分享的经验,因此有错误会虚心接受改正,但不代表此刻博文无误!


【Gitee地址】秦浩铖:​​https://gitee.com/wjw1014​