微信小程序在其他页面监听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 相关文章推荐
Jquery 基础学习笔记之文档处理
May 29 Javascript
无阻塞加载脚本分析[全]
Jan 20 Javascript
实现点击列表弹出列表索引的两种方式
Mar 08 Javascript
js防止表单重复提交的两种方法
Sep 30 Javascript
JavaScript function 的 length 属性使用介绍
Sep 15 Javascript
jQuery实现的在线答题功能
Apr 12 Javascript
非常棒的jQuery图片轮播效果
Apr 17 Javascript
详解如何理解vue的key属性
Apr 14 Javascript
微信小程序实现的绘制table表格功能示例
Apr 26 Javascript
JS中getElementsByClassName与classList兼容性问题解决方案分析
Aug 07 Javascript
何时/使用 Vue3 render 函数的教程详解
Jul 25 Javascript
javascript拖曳互换div的位置实现示例
Jun 28 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将url地址转化为完整的a标签链接代码(php为url地址添加a标签)
2014/01/17 PHP
将二维数组转为一维数组的2种方法
2014/05/26 PHP
php+mysqli实现批量执行插入、更新及删除数据的方法
2015/01/29 PHP
yii使用activeFileField控件实现上传文件与图片的方法
2015/12/28 PHP
PHP 文件锁与进程锁的使用示例
2017/08/07 PHP
在一个form用一个SUBMIT(或button)分别提交到两个处理表单页面的代码
2007/02/15 Javascript
google 搜索框添加关键字实现代码
2010/04/24 Javascript
仅IE不支持setTimeout/setInterval函数的第三个以上参数
2011/05/25 Javascript
range 标准化之获取
2011/08/28 Javascript
DWR实现模拟Google搜索效果实现原理及代码
2013/01/30 Javascript
js判断某个方法是否存在实例代码
2015/01/10 Javascript
JS动态修改表格cellPadding和cellSpacing的方法
2015/03/31 Javascript
使用vue.js2.0 + ElementUI开发后台管理系统详细教程(二)
2017/01/21 Javascript
使用vue.js编写蓝色拼图小游戏
2017/03/17 Javascript
9种改善AngularJS性能的方法
2017/11/28 Javascript
如何快速解决JS或Jquery ajax异步跨域的问题
2018/01/08 jQuery
vue使用axios上传文件(FormData)的方法
2019/04/14 Javascript
函数式编程入门实践(一)
2019/04/20 Javascript
node.js中 mysql 增删改查操作及async,await处理实例分析
2020/02/11 Javascript
微信小程序云函数添加数据到数据库的方法
2020/03/04 Javascript
基于jsbarcode 生成条形码并将生成的条码保存至本地+源码
2020/04/27 Javascript
代码块高亮可复制显示js插件highlight.js+clipboard.js整合
2021/02/15 Javascript
JavaScript 判断浏览器是否是IE
2021/02/19 Javascript
[00:43]FTP典藏礼包 DOTA2三大英雄霸气新套装
2014/03/21 DOTA
[03:27]最受玩家喜爱奖提名:PZH_Element 致玩家寄语
2016/12/20 DOTA
简单上手Python中装饰器的使用
2015/07/12 Python
Python遍历numpy数组的实例
2018/04/04 Python
python实现信号时域统计特征提取代码
2020/02/26 Python
Python select及selectors模块概念用法详解
2020/06/22 Python
AmazeUI 导航条的实现示例
2020/08/14 HTML / CSS
阿根廷在线宠物商店:Puppis
2018/03/23 全球购物
东方通信股份有限公司VC面试题
2014/08/27 面试题
介绍一下Python中webbrowser的用法
2013/05/07 面试题
个人查摆剖析材料
2014/10/04 职场文书
给原生html中添加水印遮罩层的实现示例
2021/04/02 Javascript
tomcat正常启动但网页却无法访问的几种解决方法
2022/05/06 Servers