微信小程序在其他页面监听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 相关文章推荐
JavaScript 字符串乘法
Aug 20 Javascript
Javascript String.replace的妙用
Sep 08 Javascript
jQuery添加删除DOM元素方法详解
Jan 18 Javascript
js+html5实现canvas绘制网页时钟的方法
May 21 Javascript
Node.js通过身份证号验证年龄、出生日期与性别方法示例
Mar 09 Javascript
深入理解 JavaScript 中的 JSON
Apr 06 Javascript
JS实现闭包中的沙箱模式示例
Sep 07 Javascript
浅析Vue实例以及生命周期
Aug 14 Javascript
node全局变量__dirname与__filename的区别
Jan 14 Javascript
使用nvm和nrm优化node.js工作流的方法
Jan 17 Javascript
Echarts地图添加引导线效果(labelLine)
Sep 30 Javascript
JsonProperty 的使用方法详解
Oct 11 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 程序员的调试技术小结
2009/11/15 PHP
PHP实现无限级分类(不使用递归)
2015/10/22 PHP
基于php伪静态的实现方法解析
2020/07/31 PHP
在一个浏览器里呈现所有浏览器测试结果的前端测试工具的思路
2010/03/02 Javascript
jQuery 获取URL参数的插件
2010/03/04 Javascript
javascript XMLHttpRequest对象全面剖析
2010/04/24 Javascript
JS:window.onload的使用介绍
2013/11/13 Javascript
Jquery通过Ajax访问XML数据的小例子
2013/11/18 Javascript
不提示直接关闭网页窗口的JS示例代码
2013/12/17 Javascript
JavaScript定义类的几种方式总结
2014/01/06 Javascript
java、javascript实现附件下载示例
2014/08/14 Javascript
生成二维码方法汇总
2014/12/26 Javascript
javascript中递归函数用法注意点
2015/07/30 Javascript
javascript对浅拷贝和深拷贝的详解
2016/10/14 Javascript
vue-router路由简单案例介绍
2017/02/21 Javascript
Mobile Web开发基础之四--处理手机设备的横竖屏问题
2017/08/11 Javascript
Vue.JS项目中5个经典Vuex插件
2017/11/28 Javascript
在react-router4中进行代码拆分的方法(基于webpack)
2018/03/08 Javascript
浅析vue-router原理
2018/10/19 Javascript
详解Vue项目引入CreateJS的方法(亲测可用)
2019/05/30 Javascript
原生JS实现无缝轮播图片
2020/06/24 Javascript
Python自动化构建工具scons使用入门笔记
2015/03/10 Python
windows下python连接oracle数据库
2017/06/07 Python
Python学习笔记之抓取某只基金历史净值数据实战案例
2019/06/03 Python
python字符串分割及字符串的一些常规方法
2019/07/24 Python
如何基于Python按行合并两个txt
2020/11/03 Python
使用HTML5拍照示例代码
2013/08/06 HTML / CSS
来自Ocado的宠物商店:Fetch
2018/07/10 全球购物
编写类String的构造函数、析构函数和赋值函数
2012/05/29 面试题
夫妻双方自愿离婚协议书
2014/10/24 职场文书
留学推荐信怎么写
2015/03/26 职场文书
公司员工违纪检讨书
2015/05/05 职场文书
城南旧事电影观后感
2015/06/16 职场文书
深度学习详解之初试机器学习
2021/04/14 Python
Nginx虚拟主机的搭建的实现步骤
2022/01/18 Servers
使用python求解迷宫问题的三种实现方法
2022/03/17 Python