微信小程序在其他页面监听globalData中值的变化


Posted in Javascript onJuly 15, 2019

前言

这几天去面试,多次碰到同一个知识点。而且有一次面试挺有趣的,是关于小程序的。共有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的变化)

微信小程序在其他页面监听globalData中值的变化

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

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对三水点靠木的支持。

Javascript 相关文章推荐
js wmp操作代码小结(音乐连播功能)
Nov 08 Javascript
如何用js控制frame的隐藏或显示的解决办法
Mar 20 Javascript
使用CSS样式position:fixed水平滚动的方法
Feb 19 Javascript
javascript实现youku的视频代码自适应宽度
May 25 Javascript
深入理解MVC中的时间js格式化
May 19 Javascript
jquery判断类型是不是number类型的实例代码
Oct 07 Javascript
微信公众平台开发教程(五)详解自定义菜单
Dec 02 Javascript
Vue+SpringBoot开发V部落博客管理平台
Dec 27 Javascript
基于vue-router 多级路由redirect 重定向的问题
Sep 03 Javascript
JS中appendChild追加子节点无效的解决方法
Oct 14 Javascript
javascript设计模式 ? 建造者模式原理与应用实例分析
Apr 10 Javascript
Nuxt pages下不同的页面对应layout下的页面布局操作
Nov 05 Javascript
vue中filters 传入两个参数 / 使用两个filters的实现方法
Jul 15 #Javascript
微信小程序全局变量改变监听的实现方法
Jul 15 #Javascript
vue draggable resizable 实现可拖拽缩放的组件功能
Jul 15 #Javascript
微信小程序如何使用canvas二维码保存至手机相册
Jul 15 #Javascript
如何给element添加一个抽屉组件的方法步骤
Jul 14 #Javascript
详解vuex的简单todolist例子
Jul 14 #Javascript
改进 JavaScript 和 Rust 的互操作性并深入认识 wasm-bindgen 组件
Jul 13 #Javascript
You might like
php专用数组排序类ArraySortUtil用法实例
2015/04/03 PHP
解读PHP中上传文件的处理问题
2016/05/29 PHP
Yii 2.0中场景的使用教程
2017/06/02 PHP
关于B/S判断浏览器断开的问题讨论
2008/10/29 Javascript
jquery提升性能最佳实践小结
2010/12/06 Javascript
关于JavaScript中原型继承中的一点思考
2012/07/25 Javascript
jQuery中extend函数的实现原理详解
2015/02/03 Javascript
jQuery实现的类似淘宝网站搜索框样式代码分享
2015/08/24 Javascript
javascript 动态修改css样式方法汇总(四种方法)
2015/08/27 Javascript
jquery日历插件e-calendar升级版
2016/11/10 Javascript
简单实现JavaScript图片切换效果
2016/11/28 Javascript
nodejs中sleep功能实现暂停几秒的方法
2017/07/12 NodeJs
js判断数组是否包含某个字符串变量的实例
2017/11/24 Javascript
基于vue展开收起动画的示例代码
2018/07/05 Javascript
详解axios中封装使用、拦截特定请求、判断所有请求加载完毕)
2019/04/09 Javascript
Jquery异步上传文件代码实例
2019/11/13 jQuery
Python手机号码归属地查询代码
2016/05/04 Python
python 实现删除文件或文件夹实例详解
2016/12/04 Python
Python数据结构与算法之图的最短路径(Dijkstra算法)完整实例
2017/12/12 Python
Python 查看文件的读写权限方法
2018/01/23 Python
python 获取当天每个准点时间戳的实例
2018/05/22 Python
Python实现分段线性插值
2018/12/17 Python
python和mysql交互操作实例详解【基于pymysql库】
2019/06/04 Python
Python搭建代理IP池实现获取IP的方法
2019/10/27 Python
python requests抓取one推送文字和图片代码实例
2019/11/04 Python
Python操作MongoDb数据库流程详解
2020/03/05 Python
如何基于python3和Vue实现AES数据加密
2020/03/27 Python
django实现后台显示媒体文件
2020/04/07 Python
keras model.fit 解决validation_spilt=num 的问题
2020/06/19 Python
Python Pandas list列表数据列拆分成多行的方法实现
2020/12/14 Python
html5 touch事件实现触屏页面上下滑动(二)
2016/03/10 HTML / CSS
深入解析HTML5的IndexedDB索引数据库
2015/09/14 HTML / CSS
业务总经理岗位职责
2014/02/03 职场文书
幼儿园教师管理制度
2015/08/05 职场文书
教师节主题班会教案
2015/08/17 职场文书
Redis高可用集群redis-cluster详解
2022/03/20 Redis