手记

微信小程序全局状态管理和跨页通讯-使用Westore就够了

现在市面上有很多小程序的框架,看上去都挺高大上,但是实际用起来却没能真正解决项目的痛点,一般的都是为了写法的方便都差不多运用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


1人推荐
随时随地看视频
慕课网APP

热门评论

没看懂你写的!!!!

查看全部评论