// app.js中
//app.js
App({
onLaunch: function () {
let that = this
// 在这里用定时器模拟网络请求的过程
setTimeout(function(){
that.globalData.name = 'pxh'
},3000)
},
// 这里这么写,是要在其他界面监听,而不是在app.js中监听,而且这个监听方法,需要一个回调方法。
watch:function(fn){
var obj = this.globalData;
Object.defineProperty(obj,"name", {
configurable: true,
enumerable: true,
set: function (value) {
this._name = value;
fn(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)
}
小程序遇到的问题: openid 获取不到的问题
原因: 业务模块需要获取到openid 才能进行接口调用, 但是openid 也是通过接口获取的, 那么就可能 因为时序的问题,业务接口会先调用,导致没有获取到openid,
解决办法:
app.js
// 由于这里是网络请求,可能会在 Page.onLoad 之后才返回 所以此处加入 callback 以防止这种情况
if (that.defaultLoginCallback) {
that.defaultLoginCallback({ openId, unionId });
}
业务模块使用:
if(!unionId){
app.defaultLoginCallback = res => {
that.setData({
unionId: res.unionId
})
}
}else{
that.setData({
unionId: unionId
})
}