当前位置:   article > 正文

微信小程序监听App中的globalData——全局数据监听_wx app globaldata

wx app globaldata


需求:微信小程序项目需要全局监听某个数据。
方法:在 app.ts/app.js 中定义 globalData 公共数据,然后定义一个监听方法 watch,在其他页面或组件中通过使用 【发布订阅 】 模式,进行数据的监听操作。

定义数据

// app.ts

App<IAppOption>({
    globalData: {
        count:0
    },
})
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7

定义监听方法

使用 Object.defineProperty 方法进行数据监听

// app.ts

App<IAppOption>({
    globalData: {
        count:0
    },
    watch: function (variate: any, method: any) {
        var obj = getApp().globalData;
        let val = obj[variate];
        Object.defineProperty(obj, variate, {
            set: function (value) {
                val = value;
                method(variate, value);
            },
            get: function () {
                return val;
            }
        })
    }
 })
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20

注册监听方法

在需要监听的组件中注册app().watch 方法

// xxCompinents.ts

Component({
	data: {
        count: 0
    },
	lifetimes:{
		attached(){
			getApp().watch('count', () => {
                this.setData({
                    count: getApp().globalData.count
                })
            });
		}
	}
})
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16

修改监听的数据

在项目中任何页面或组件中,修改count都能被监听到

// xxPage.ts

Page({
	handleSetCount(){
		getApp().globalData.count = 1
	},
	handleSetCount(){
		console.log(getApp().globalData.count)
	}
})
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10

调用 handleSetCount 方法,即可xxComponent 中的count。

扩展

可以结合之前的全局登录弹窗使用
微信小程序全局登录弹窗(https://blog.csdn.net/qq_45142260/article/details/128844351#comments_32228729)

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/2023面试高手/article/detail/504957
推荐阅读
相关标签
  

闽ICP备14008679号