加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 综合聚焦 > 资源网站 > 资源 > 正文

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

发布时间:2020-12-14 19:15:07 所属栏目:资源 来源:网络整理
导读:前言 这几天去面试,多次碰到同一个知识点。而且有一次面试挺有趣的,是关于小程序的。共有3个问题。 1、小程序中Page.watch()方法是做什么用的? 2、小程序中如何在其他页面中监听到globalData中值的变化? 3、如果在app.js执行登录部分的代码,由于时序问

前言

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

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

知识点

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

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

  1. // app.js中
  2. App({
  3. onLaunch: function () {
  4. let that = this
  5. // 在这里用定时器模拟网络请求的过程
  6. setTimeout(function(){
  7. that.globalData.name = 'pxh'
  8. },3000)
  9. },
  10. // 这里这么写,是要在其他界面监听,而不是在app.js中监听,而且这个监听方法,需要一个回调方法。
  11. watch:function(method){
  12. Object.defineProperty(obj,"name",{
  13. configurable: true,197);'>
    this._name = value;
  14. console.log('是否会被执行2')
  15. method(value);
  16. },197);'>
    // 可以在这里打印一些东西,然后在其他界面调用getApp().globalData.name的时候,这里就会执行。
  17. }
  18. })
  19. userInfo: null,197);'>
  20. }
  21. })
  22. onLoad: function (options) {
  23. getApp().watch(that.watchBack)
  24. + name)
  25. }

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

image.png

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

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读