使用watch在微信小程序中实现全局状态共享
问题
在之前开发微信小程序的时候,获取用户信息、openid还有地理位置这些信息的时候,都是采用Promise的方式异步获取,这样的话在页面和App.js中都获取就可能造成请求重复的问题。
比如为了在每个页面都能获取到这些共享信息,都会选择在App.js中进行获取,然后在页面级进行获取,这两次获取的时间间隔较小时就可能导致前一个请求还未获取到数据,后一个请求就会进行获取,这样就产生了两次请求。
还有一个问题就是书写麻烦(虽然也能通过async await简化),比如
onLoad() { app.getUserInfo() .then(userInfo => { }).catch(err => { / 错误处理 / }); // 如果需要userInfo和openid,可能就是如下形式 Promise.all([app.getUserInfo(), app.getOpenid()]) .then(res => { }).catch(err => { / 错误处理 / }); }
正好周末的时候突然想到了vue的watch语法,利用一些相关的知识,就可以解决这个麻烦的问题了。
解决思路
双向绑定
vue的双向绑定原理,3.0将会采用Proxy监听数据变化,不过考虑到小程序这边的Proxy兼容性我不知道,所以采用了2.0的Object.defineProperty
来监听数据的变化。
主要还是拦截设置的操作,在进行赋值时,将新旧值通知至监听者。
观察者模式
在页面级的onLoad监听app.globalData
各个键名的事件,而在app.js的onLoad中则使用Object.defineProperty
重新定义app.globalData
,这样一旦app.globalData
相应的键值发生了变化,就会通知监听的页面该值发生了变化。
模块化的引用
观察者模式导出的是一个对象(类实例),而不是一个类,所以在导入的时候这个对象是共享的,就可以通过这个对象将app.js和其他页面联系起来。
至于模块加载的实质,ES6模块加载的机制,与CommonJS模块完全不同。感兴趣的可以去看看。
封装Page
小程序的Page函数本身是不支持watch,我们可以自定义一个函数,进行参数合并就可以了。
在页面onLoad时先遍历watch属性,对app.globalData
进行监听,可以参考vue的watch用法。
页面onUnload时就会进行销毁,此时也应该取消监听,这些我都封装过了,不用手动处理了。
有了这些思路,用不了多久,一个雏形就出来了,经过手动测试,感觉没什么问题,我就发布到npm了,大家感兴趣的可以安装体验一下。
安装
npm i wx-watch -S --production
使用
// app.js var { watchData, } = require('/miniprogram_npm/wx-watch/index.js'); App({ onLaunch() { this.watchData(); / 监听this.globalData的变化,并触发事件,其他页面监听的值必须在globalData中预先定义,否则无法监听 / }, watchData, globalData: { userInfo: null, } }); // 其他需要监听globalData的页面.js var { getPage } = require('../../miniprogram_npm/wx-watch/index.js'); const app = getApp(); / getPage(页面参数,app) app必传,因为封装的时候访问不到,就只能传参了 / getPage({ watch: { userInfo(userInfo, oldUserInfo) { console.log(`来自app.glodalData的userInfo`); } }, // 其他参数 }, app)
github: …
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对狼蚁SEO的支持。
编程语言
- 如何快速学会编程 如何快速学会ug编程
- 免费学编程的app 推荐12个免费学编程的好网站
- 电脑怎么编程:电脑怎么编程网咯游戏菜单图标
- 如何写代码新手教学 如何写代码新手教学手机
- 基础编程入门教程视频 基础编程入门教程视频华
- 编程演示:编程演示浦丰投针过程
- 乐高编程加盟 乐高积木编程加盟
- 跟我学plc编程 plc编程自学入门视频教程
- ug编程成航林总 ug编程实战视频
- 孩子学编程的好处和坏处
- 初学者学编程该从哪里开始 新手学编程从哪里入
- 慢走丝编程 慢走丝编程难学吗
- 国内十强少儿编程机构 中国少儿编程机构十强有
- 成人计算机速成培训班 成人计算机速成培训班办
- 孩子学编程网上课程哪家好 儿童学编程比较好的
- 代码编程教学入门软件 代码编程教程