// app.js中
//app.js
App({
  onLaunch: function () {
    let that = this
    // 在这里用定时器模拟网络请求的过程
    setTimeout(function(){
      that.globalData.name = 'pxh'
    },3000) 
  },
 // 这里这么写,是要在其他界面监听,而不是在app.js中监听,而且这个监听方法,需要一个回调方法。
  watch:function(fn){
    var obj = this.globalData;
    Object.defineProperty(obj,"name", {
      configurable: true,
      enumerable: true,
      set: function (value) {
        this._name = value;
        fn(value);
      },
      get:function(){
      // 可以在这里打印一些东西,然后在其他界面调用getApp().globalData.name的时候,这里就会执行。
        return this._name
      }
    })
  },
  globalData: {
    userInfo: null,
    _name:'msr'
  }
})
 
 
// 然后在index.js中的声明周期中实现
onLoad: function (options) {
    let that = this;
    getApp().watch(that.watchBack)
  },
  watchBack: function (name){
    console.log(22222);
    console.log('this.name==' + name)
  }

小程序遇到的问题: openid 获取不到的问题

原因: 业务模块需要获取到openid 才能进行接口调用, 但是openid 也是通过接口获取的, 那么就可能 因为时序的问题,业务接口会先调用,导致没有获取到openid,

解决办法: 

app.js
  // 由于这里是网络请求,可能会在 Page.onLoad 之后才返回  所以此处加入 callback 以防止这种情况
    if (that.defaultLoginCallback) {
      that.defaultLoginCallback({ openId, unionId });
    }


业务模块使用:

    if(!unionId){
      app.defaultLoginCallback = res => {
        that.setData({
          unionId: res.unionId
        })
      }
    }else{
      that.setData({
        unionId: unionId
      })
    }

Logo

华为开发者空间,是为全球开发者打造的专属开发空间,汇聚了华为优质开发资源及工具,致力于让每一位开发者拥有一台云主机,基于华为根生态开发、创新。

更多推荐