小程序如何在其他页面监听globalData中值的变化?

前言

这几天去面试,多次碰到同一个知识点。而且有一次面试挺有趣的,是关于小程序的。共有3个问题。

  • 1、小程序中Page.watch()方法是做什么用的?
  • 2、小程序中如何在其他页面中监听到globalData中值的变化?
  • 3、如果在app.js执行登录部分的代码,由于时序问题,如何处理其他页面请求时未获取到身份识别标记的情况。(session,userid等)。(大意是:怎么能够保证其他页面请求是在登录之后?)

知识点

有经验的同学可能一下子就看出来了,这其实说的是同一个东西,那就是Object.defineproperty()这个方法。
下面我来尝试回答一下:
第一题:小程序中并没有Page.watch()方法,但其实这里面试官的要问的东西就是第二题的题目,也就是属性监听器。

第二题:由于要监听到globalData中的值的变化,所以一般要在globalData改变时回调一个方法。例如我们监听一个name属性,大致代码如下:

// app.js中
//app.js
App({
  onLaunch: function () {
    let that = this
    // 在这里用定时器模拟网络请求的过程
    setTimeout(function(){
      that.globalData.name = 'pxh'
    },3000) 
  },
 // 这里这么写,是要在其他界面监听,而不是在app.js中监听,而且这个监听方法,需要一个回调方法。
  watch:function(method){
    var obj = this.globalData;
    Object.defineProperty(obj,"name", {
      configurable: true,
      enumerable: true,
      set: function (value) {
        this._name = value;
        console.log('是否会被执行2')
        method(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)
  }

看看执行效果(可以看到,我们在其他界面完美实现了监听到globalData的变化)


image.png

第三题:emmm。第二题的答案就是第三题的答案啦。我们可以在index.js中的回调方法中再进行网络请求,请求需要识别身份的资源。

推荐阅读更多精彩内容

  • 发现 关注 消息 iOS 第三方库、插件、知名博客总结 作者大灰狼的小绵羊哥哥关注 2017.06.26 09:4...
    肇东周阅读 9,960评论 4 55
  • 微信小程序自定义组件的使用,来自项目的总结 一直以来忙项目都没有什么时间来写博客,今天晚上刷了会儿csdn,知乎等...
    27亿光年中的小小尘埃阅读 3,935评论 2 11
  • “世间惟你好”。 遇见佳丽大概是在15年7月。 嗯,我一个人去陌生的学校补课,拘谨得不得了,佳丽是我在那段时间认识...
    铃铛十分小清新阅读 188评论 0 1
  • 等着合肥的提成过来,一直都没有来。客户拖的太久,拖得我快要疯掉了。他不明了我现在的状况,这笔钱可是救命钱,是我的全...
    陈清伟阅读 128评论 0 0
  • 江日照曾经进入过我的心里。 我清楚的明白,我还是第一次主动跟人提处关系。他被放在一个很重要的位置,高于京鸿,和几几...
    赵清扬阅读 87评论 0 0