微信小程序在其他页面监听globalData中值的变化
微信(小程序)  /  管理员 发布于 4年前   500
前言
这几天去面试,多次碰到同一个知识点。而且有一次面试挺有趣的,是关于小程序的。共有3个问题。
1、小程序中Page.watch()
方法是做什么用的?
2、小程序中如何在其他页面中监听到globalData中值的变化?
3、如果在app.js执行登录部分的代码,由于时序问题,如何处理其他页面请求时未获取到身份识别标记的情况。(session,userid等)。(大意是:怎么能够保证其他页面请求是在登录之后?)
知识点
有经验的同学可能一下子就看出来了,这其实说的是同一个东西,那就是Object.defineproperty()
这个方法。
下面我来尝试回答一下:
第一题:小程序中并没有Page.watch()
方法,但其实这里面试官的要问的东西就是第二题的题目,也就是属性监听器。
第二题:由于要监听到globalData中的值的变化,所以一般要在globalData改变时回调一个方法。例如我们监听一个name属性,大致代码如下:
// app.js中//app.jsApp({ 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的变化)
第三题:emmm。第二题的答案就是第三题的答案啦。我们可以在index.js中的回调方法中再进行网络请求,请求需要识别身份的资源。
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家的支持。
123 在
Clash for Windows作者删库跑路了,github已404中评论 按理说只要你在国内,所有的流量进出都在监控范围内,不管你怎么隐藏也没用,想搞你分..原梓番博客 在
在Laravel框架中使用模型Model分表最简单的方法中评论 好久好久都没看友情链接申请了,今天刚看,已经添加。..博主 在
佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 @1111老铁这个不行了,可以看看近期评论的其他文章..1111 在
佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 网站不能打开,博主百忙中能否发个APP下载链接,佛跳墙或极光..路人 在
php中使用hyperf框架调用讯飞星火大模型实现国内版chatgpt功能示例中评论 教程很详细,如果加个前端chatgpt对话页面就完美了..Copyright·© 2019 侯体宗版权所有· 粤ICP备20027696号