小编推荐:Fundebug专注于JavaScript、微信小程序、微信小游戏,Node.js和Java实时BUG监控。真的是一个很好用的bug监控费服务,众多大佬公司都在使用。

前言

这几天去面试,多次碰到同一个知识点。而且有一次面试挺有趣的,是关于小程序的。共有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中的回调方法中再进行网络请求,请求需要识别身份的资源。

作者:甚时跃马归来
链接:https://www.jianshu.com/p/8d1c4626f9a3
来源:简书
简书著作权归作者所有,任何形式的转载都请联系作者获得授权并注明出处。

你可能感兴趣的

  • 黑科技!Fundebug支持网页录屏!

  • Async/Await替代Promise的6个理由

  • 30个极大提高开发效率的VS Code插件

  • 10个JavaScript难点

  • 2018前端工程师成长路线图

  • Source Map入门教程

  • 2018年最值得关注的30个Vue开源项目

  • 10个最佳ES6特性

  • 重新思考单元测试

  • 不要争了!技术选择没那么重要

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

  1. 微信小程序app.js中的全局变量globalData改变,如何通知其它页面界面显示改变,小程序中如何在其他页面中监听到globalData中值的变化

    微信小程序app.js中的全局变量globalData改变,如何通知其它页面界面显示改变,小程序中如何在其他页面中监听到globalData中值的变化 在小程序中,我们一般在app.js的onLaun ...

  2. uniapp微信小程序左上角返回按钮的监听

    项目场景: uni-app 开发微信小程序,界面中点击左上角的返回按钮或者是系统自带的虚拟返回操作,返回前监听用户是否在页面内进行了相应操作,如果有则进行提示(提示用户是否确定要返回),如果没有则直接 ...

  3. JavaScript 实时监听input 中值变化

    JavaScript 实时监听input 中值变化 在 <input> 标签中,添加属性 oninput ,oninput 事件在元素获得用户输入时发生. 当 <input> ...

  4. Vue.js开发记录--用watch监听对象中属性的变化

    监听对象中所有属性 存在对象obj,若想要监听其中所有的值的变化 watch: {obj: {handler (val) {// coding},deep: true}, } 监听对象中某个属性 如果 ...

  5. 小程序横屏竖屏切换监听

    一.在需要切换的页面.json中配置代码 注:需要提前开启手机的屏幕旋转 {"usingComponents": {"nav-bar": "/pack ...

  6. 微信小程序全局监听globalData的某个属性变化

    前言 近日在开发微信小程序的时候,要将globalData中某个属性的变化要同步到某个页面中. 使用Object.defineProperty()监听属性全局更改 经过上网查询相关资料,参考vue实现 ...

  7. 微信小程序 - 全局监听globalData的某个属性变化,例如监听网络状态切换

    前言 近日公司小程序项目中有个需求,商品列表页及商品详情页配置视频,视频在WiFi环境下自动播放,非WiFi环境下暂停播放. 一.小程序有获取网络类型的API wx.getNetworkType(Ob ...

  8. 小程序 吸顶tab 滚动监听

    思路 position sticky 配合滚动监听 锚点跳转 自定义tab <bg-navigation-bar showBack="{{true}}"bgurl=" ...

  9. Document.visibilityState 页面监听 vue中实现离开页面时计时停止: 停止计时后从上一次开始计时

    概述 Document.visibilityState (只读属性), 返回document的可见性, 即当前可见元素的上下文环境. 由此可以知道当前文档(即为页面)是在背后, 或是不可见的隐藏的标签 ...

最新文章

  1. ASP.NET AJAX(开发代号:Atlas)的相关问题请在本帖中提出
  2. C++ Primer 5th笔记(chap 14 重载运算和类型转换)类类型转换
  3. [Python] Window机器上同时安装Python 2 和 Python 3,如何兼容切换使用?
  4. 使用java 自带的webservice
  5. 11下滑半个屏幕_努比亚发布手表手机:柔性屏幕,体积感人
  6. 解决python在pycharm中可以import本地文件,但命令行运行时报错:no model named xxxx本地文件
  7. 【Oracle】创建用户
  8. maven下载,安装与eclipse中maven配置
  9. oracle数据表丢失数据库,Oracle数据库数据丢失恢复的几种方法总结
  10. Android 文件管理器 Android文件管理器源代码
  11. 数据分析入门——深入浅出数据分析
  12. 你技术这么好,总要改变点什么把!
  13. 手机端html5页面横屏显示,移动端HTML5中判断横屏竖屏的方法
  14. 计算机无法安装MUMU模拟器,电脑手机模拟器,详细教您电脑手机模拟器MuMu模拟器怎么使用...
  15. mysql按照音序排列_如何按音序排列
  16. python中的计数函数_NumPy的搜索和计数函数
  17. 【烈日炎炎战后端】计算机网络(4.2万字)
  18. 转载:做人开心最重要
  19. 《 QT5.9 c++ 开发指南》各种常见图表的绘制(一个例子让你不再担心表图的绘制)
  20. 如何简单的模拟发送http post请求

热门文章

  1. 【JZOJ】【匈牙利算法】【二分】 导弹
  2. MUR60120PT-ASEMI整流二极管MUR60120PT
  3. 随笔-浅谈技术核心竞争力
  4. MUR1660AC-ASEMI超快恢复二极管MUR1660AC
  5. 直接排序三种方法参考——监视哨
  6. linux opengl配置编译,Linux下OpenGL的安装与cmake编译OpenGL程序
  7. 手把手带你拆解 LRU 算法
  8. 极光推送官网能发送成功而手机端却收不到推送
  9. ElementUI 表单单个验证
  10. elastic-job之运维平台