微信小程序如何在公共组件中改变某一个页面的属性值

需求

公共组件A改变页面B的属性isShow的值。

思路

首先目前我不了解可以直接在组件中改变页面的值的方法,所以我通过监听的方式在B页面监听app.js的某一属性值的改变从而改变B页面的值,众所周知app.js的某一属性值是很容易就能更改的。

app.js
javascript 复制代码
  globalData: {
    isShow: false
  },//给app.js中被监听的值赋初始值
    // 使用数据劫持模式监听数据变化
  observe(obj, key, watch, that) {
    let val = obj[key];
    Object.defineProperty(obj, key, {
      configurable: true,
      enumerable: true,
      set: function (value) {
        watch(val, value, that);
        val = value;
      },
      get: function () {
        return val;
      }
    })
  }

B页面

javascript 复制代码
  data:{
    isShow:false
  },
  //在onReady中调用app.js的observe,并且传参,第二个参数为要监听的app.js的属性值
  onReady() {
    const app = getApp()
    app.observe(app.globalData, "isShow", this.watch, this);
  },
  watch(oldVal, newVal, that) {
    that.setData({
      isShow: newVal//监听后得到新的值,并将新的值赋值给页面的这个我们要改变的这个属性
    })
  }

A组件

组件中只需要在你需要改变页面值的时候改变一下app.js的所被监听的这个属性的值即可。

javascript 复制代码
getApp().globalData.isShow = true
相关推荐
30767 小时前
uni-app在微信小程序国际化分包方案:优雅解决主包体积超限问题
微信小程序
文慧的科技江湖12 小时前
光储充一体化开源能源管理系统 需求说明书(简单版) - 慧知开源充电桩平台
小程序·开源·能源·光储充·光伏系统·实现光储充全设备统一监控·光储充一体化开源能源管理系统
eric*168814 小时前
Mac反编译小程序教程
小程序·小程序反编译
打瞌睡的朱尤15 小时前
微信小程序50~75
微信小程序·小程序
ZC跨境爬虫15 小时前
【零基础实战】Fiddler抓取PC微信小程序数据流,爬取华为商城商品配置+真实评论(完整可运行代码+逐行解析)
测试工具·微信小程序·fiddler
weixin_3947580319 小时前
直播间小程序码生成问题修复代码清单
android·小程序·apache
程序鉴定师2 天前
上海本凡科技解密小程序开发公司的价格构成与市场价值
大数据·小程序
hnxaoli2 天前
win10小程序(十九)鼠标位置记录
python·小程序
IT观测2 天前
# 2026年SaaS小程序制作平台对比:乔拓云、有赞、微盟
小程序
宁夏雨科网2 天前
印刷包装公司开发小程序的优势与内容
小程序·展示小程序·印刷包装·印刷公司小程序