小程序全局变量与组件内部实时监听全局变量的改变

前言:

        小程序的全局变量的设置与修改,并且在页面内部、组件内部实时监听我们全局变量的改动,来实现我们的一些功能效果,比如全局弹框,比如全局loadding效果等等。

实现效果:

        请求后台前展示loadding,

        请求后台后关闭loadding

 

实现步骤:

1、全局变量的设置与修改

app.js中配置:

App({
    
  //全局监听loadding状态
  watch:function(method){
    var obj = this.globalData;
    //注意,这里的comLoadding对应的是globalData定义的变量
    Object.defineProperty(obj,"comLoadding", {
      configurable: true,
      enumerable: true,
      set: function (value) {
        //_comLoadding 是自己起的名字,只要和get里面的保持统一就行,方法内部使用变量
        this._comLoadding = value;
        method(value);
      },
      get:function(){
        return this._comLoadding
      }
    })
  },  
  globalData: {
    comLoadding:false
  }
    

})

2、页面内部监听与修改

监听方法:

onLoad: function (options) {
     /**
     * @tip:loadding的控制状态与全局的控制字段连接
     *       1、组件初始化
     *       2、绑定组件内部watch
     * @time 2022.9.7
     * @author zwh
     * ---------------------START--------------------------
     * */
    const self = this;
    // 注意:watchBack后面要重新绑定this,否则下边的this找不到
    getApp().watch(self.watchBack.bind(self));
    // ---------------------END--------------------------
},
// 监听全局的loadding状态
watchBack(comLoadding){

    // 监听数据会拿到与当前值相同的数据
    if(comLoadding === this.data.loadingFlag) return
    // 关闭loadding增加延时效果,目的是效果展示
    if(!comLoadding){
      setTimeout(()=>{
        this.setData({
          loadingFlag:comLoadding,
        })
      },500)
    }else{
      this.setData({
        loadingFlag:comLoadding,
      })
    }

},

修改公共变量方法:

//修改全局的内容
getApp().globalData.comLoadding = true  
getApp().globalData.comLoadding = false

3、组件内部监听

监听方法:

Component({
    pageLifetimes: {
        show() {
            
            /**
               * @tip:loadding的控制状态与全局的控制字段连接
               *       1、组件初始化
               *       2、绑定组件内部watch
               * @time 2022.9.7
               * @author zwh
               * ---------------------START--------------------------
               * */
                  const self = this;
                  // 注意:watchBack后面要重新绑定this,否则下边的this找不到
                  getApp().watch(self.watchBack.bind(self));
              // ---------------------END--------------------------

        }
    },
    methods: {
        // 监听全局的loadding状态
        watchBack(comLoadding){
          // 监听数据会拿到与当前值相同的数据
          if(comLoadding === this.data.loadingFlag) return
          // 关闭loadding增加延时效果,目的是效果展示
          if(!comLoadding){
            setTimeout(()=>{
              this.setData({
                loadingFlag:comLoadding,
              })
            },500)
          }else{
            this.setData({
              loadingFlag:comLoadding,
            })
          }
        },
    }


})

修改公共变量方法:

//修改全局的内容
getApp().globalData.comLoadding = true  
getApp().globalData.comLoadding = false

4、公共 请求接口中  request.js中改变公共变量

//打开loadding
const noNeedLoaddingRouters = ['consumer/live/room-product-list','consumer/loadingImg/find-loading-img']
let needLodding = noNeedLoaddingRouters.filter(v => v === url.split('api/live/')[1]).length > 0 ? true : false
if(!needLodding){
   getApp().globalData.comLoadding = true
}

//请求接口
wx.request({
    url: url,
    data,
    method,
    header: {},
    success:async (res) => {
        //关闭loadding
        getApp().globalData.comLoadding = false

    },
    fail: (error) => {
        //关闭loadding
        getApp().globalData.comLoadding = false

    }
}

  • 6
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 4
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值