Day 281/300 微信小程序 监听接口返回的数据后 动态赋值并展示

(一)现状

1、一开始使用的缓存+setTimeout,缺点是不知道什么时候回来;网络速度慢的时候,会有空白的情况,或者是需要连续发,不太好;

2、想实现监听接口返回的数据后 动态赋值并展示的效果;

还可以用 状态管理的方式,mobx-miniprogram

(二)实现的代码

1、app.ts

ts 复制代码
// app.ts
App<IAppOption>({
  globalData: {
    setting: 'prod', // prod  dev
  },
  // 监听全局变量变化
  watch: function (variate, method) {
    var obj = this.globalData;
    let val = obj[variate]; // 单独变量来存储原来的值
    Object.defineProperty(obj, variate, {
      configurable: false,
      enumerable: true,
      set: function (value) {
        val = value; // 重新赋值
        method(variate, value); // 执行回调方法
      },
      get: function () {
        // 在其他界面调用getApp().globalData.variate的时候,这里就会执行。
        return val; // 返回当前值
      }
    })
  },
  onLaunch() {
    const that = this
    // 登录
    wx.login({
      success: res => {
        // console.log('code---',res.code)
        if(!wx.getStorageSync("token")){
          wx.request({
            url: this.globalData.url + '/login',
            method: 'GET',
            data: {
              "code":res.code
            },
            header: {
              'content-type': 'application/json'
            },
            success (res) {
              const response = res.data.data
              const token = response && response.user_setting && response.user_setting.token || ''
              const template = response && response.user_setting && response.user_setting.template || []
              const balance = response && response.user_setting && response.user_setting.balance || []
              that.globalData.template = template;
              that.globalData.balance = balance;
              wx.setStorageSync("token",token)
              wx.setStorageSync("template",template)
              wx.setStorageSync("balance",balance)
            }
          })
        }
      },
    })

  },
})

2、首页

ts 复制代码
Page({
  data: {
    balance: '',
  },
  watchCallBack(name: string, value: any) {
    // console.log('watchBack', name, value);
    if (name === 'balance') {
      this.setData({
        balance: value,
      });
    }
  },
  onLoad() {
    // @ts-ignore
    getApp().watch('balance', this.watchCallBack)
  },
  onReady() {
    
  },
  onShow() {

  },
})

参考链接

https://juejin.cn/post/7241101553712955451

相关推荐
黑客老李8 小时前
web渗透实战 | js.map文件泄露导致的通杀漏洞
安全·web安全·小程序·黑客入门·渗透测试实战
游戏开发爱好者818 小时前
日常开发与测试的 App 测试方法、查看设备状态、实时日志、应用数据
android·ios·小程序·https·uni-app·iphone·webview
2501_9151063220 小时前
app 上架过程,安装包准备、证书与描述文件管理、安装测试、上传
android·ios·小程序·https·uni-app·iphone·webview
2501_9151063220 小时前
使用 Sniffmaster TCP 抓包和 Wireshark 网络分析
网络协议·tcp/ip·ios·小程序·uni-app·wireshark·iphone
宠友信息21 小时前
2025社交+IM及时通讯社区APP仿小红书小程序
java·spring boot·小程序·uni-app·web app
“负拾捌”1 天前
python + uniapp 结合腾讯云实现实时语音识别功能(WebSocket)
python·websocket·微信小程序·uni-app·大模型·腾讯云·语音识别
换日线°2 天前
NFC标签打开微信小程序
前端·微信小程序
光影少年2 天前
AIGC + Taro / 小程序
小程序·aigc·taro
2501_915918412 天前
在 iOS 环境下查看 App 详细信息与文件目录
android·ios·小程序·https·uni-app·iphone·webview
2501_916007472 天前
没有 Mac 用户如何上架 App Store,IPA生成、证书与描述文件管理、跨平台上传
android·macos·ios·小程序·uni-app·iphone·webview