globalData パラメータの変更を監視する
//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)
}
カスタムコンポーネントフィールドの変更をリッスンする
observers: {
'addressText': function (val1, val2) {
console.log(11111)
}
},