现在市面上有很多小程序的框架,看上去都挺高大上,但是实际用起来却没能真正解决项目的痛点,一般的都是为了写法的方便都差不多运用vue的写法进行改造,但是小程序本身具有组件化、开发、调试、发布、灰度、回滚、上报、统计、监控和最近的云能力都很强悍,有时真没必要还要去查看其它框架两份文档进行开发。
通过一段时间的小程序开发,发现小程序现在的痛点其实真正是全局状态管理和跨页面通信,就像vuex进行状态管理,虽然也有类似Redux状态管理库,但是使用起来比较麻烦。 有时候要定义一个全局的数据往往会弄缓存,但是这是下下策。
最近看到大神写Westore框架或者说成是库吧,嘛嘛再也不用担心我编程了。下面就入门级的介绍一下这个框架的使用。
一、页面结构
页面结构
项目结构和原生的目录没有区别,只不过主要多加了在utils里面的diff.js、create.js以及store.js。里面的diff是核心的库文件,create主要是页面注册用的,而store就是管理全局的数据中心。是不是一目了然。
二、页面注册及组件注册
创建页面
创建 Page 只需传入两个参数,store 从根节点注入,所有子组件都能通过 this.store 访问。原生的方法还是一样使用,不影响。 this.update()类似this.setData()但是 this.update 调用的 setData 是 diff 后的,所以传递的数据更少。
import store from '../../store'import create from '../../utils/create'const app = getApp() create(store, { onLoad: function () { if (app.globalData.userInfo) { this.store.data.userInfo = app.globalData.userInfo this.store.data.hasUserInfo = true this.update() } else if (this.data.canIUse) { app.userInfoReadyCallback = res => { this.store.data.userInfo = res.userInfo this.store.data.hasUserInfo = true this.update() } } else { wx.getUserInfo({ success: res => { app.globalData.userInfo = res.userInfo this.store.data.userInfo = res.userInfo this.store.data.hasUserInfo = true this.update() } }) } } })
绑定数据
和以前的写法没有差别,直接把 store.data 作为绑定数据源。
创建组件
和创建 Page 不一样的是,创建组件只需传入一个参数,不需要传入 store,因为已经从根节点注入了。
import create from '../../utils/create'create({ ready: function () { //you can use this.store here }, methods: { //you can use this.store here } })
跨页面同步数据
使用 westore 你不用关心跨页数据同步,你只需要专注 this.store.data 便可,修改完在任意地方调用 update 便可
感觉使用是不是很简单并且this.update 比原生 setData 的性能更优,更加智能。
作者:独孤久见
链接:https://www.jianshu.com/p/85eb03a14f9f
共同学习,写下你的评论
评论加载中...
作者其他优质文章