微信小程序使用 MoxB 实现全局状态管理
admin
2024-02-20 09:15:44
0

github 地址:https://github.com/wechat-miniprogram/mobx-miniprogram-bindings

安装 MobX:

  1. 在小程序根目录下执行 npm install --save mobx-miniprogram mobx-miniprogram-bindings 安装 mobx-miniprogrammobx-miniprogram-bindings
  2. 点击开发者工具中的菜单栏:工具 --> 构建 npm 完成构建。

创建 MobX Store:

在小程序根目录下新建 store.js文件,创建 MobX Store。

// store.js
import { observable, action } from "mobx-miniprogram";export const store = observable({// 数据字段numA: 1,numB: 2,// 计算属性get sum() {return this.numA + this.numB;},// actionsupdateNumA: action(function () {this.numA = 3;}),
});

使用 MobX Store:

将页面、自定义组件和 store 绑定有两种方式: behavior 绑定和手工绑定 。

  1. behavior 绑定:使用 storeBindingsBehavior 这个 behavior 和 storeBindings 定义段。
    import { storeBindingsBehavior } from "mobx-miniprogram-bindings";
    Component({behaviors: [storeBindingsBehavior],storeBindings: {// 绑定配置},// 也可以把 storeBindings 设置为一个数组,可以同时绑定多个 storestoreBindings: [{// 绑定配置 1},{// 绑定配置 2},],
    })
    
  2. 手工绑定: 使用 createStoreBindings 创建绑定,它会返回一个包含清理函数的对象用于取消绑定。

    在页面 onUnload 或自定义组件 detached 时一定要调用清理函数,否则将导致内存泄漏。

    import { createStoreBindings } from "mobx-miniprogram-bindings";Page({onLoad() {this.storeBindings = createStoreBindings(this, {// 绑定配置});},onUnload() {this.storeBindings.destroyStoreBindings();},
    });
    

无论使用哪种绑定方式,都必须提供一个绑定配置对象。这个对象包含以下字段:

  1. store:一个 MobX observable。用于指定默认的 MobX store。
  2. fields:数组或对象。用于指定需要绑定的 data 字段。
    fields 有三种形式:
    • 数组形式:指定 data 中哪些字段来源于 store 。例如 ['numA', 'numB']
    • 映射形式:指定 data 中哪些字段来源于 store 以及它们在 store 中对应的名字。例如 { a: 'numA', b: 'numB' } ,此时 this.data.a === store.numAthis.data.b === store.numB
    • 函数形式:指定 data 中每个字段的计算方法。例如 { a: () => store.numA, b: () => anotherStore.numB } ,此时 this.data.a === store.numAthis.data.b === anotherStore.numB
  3. actions:数组或对象。用于指定需要映射的 actions,将 store 中的一些 actions 放入页面或自定义组件的 this 下。
    actions 有两种形式:
    • 数组形式:例如 ['update'] ,此时 this.update === store.update
    • 映射形式:例如 { buttonTap: 'update' } ,此时 this.buttonTap === store.update

为了提升性能,在 store 中的字段被更新后,并不会立刻同步更新到 this.data 上,而是等到下个 wx.nextTick 调用时才更新,这样可以显著减少 setData 的调用次数。
如果需要立刻更新,可以在 behavior 绑定中调用 this.updateStoreBindings(),或者在手工绑定中调用 this.storeBindings.updateStoreBindings()

如果只是更新对象中的一部分,是不会引发界面变化的。
例如:this.someObject.someField = "xxx"; 是不会触发界面更新的,可以改成this.someObject = Object.assign({}, this.someObject, { someField: "xxx" });

在 Component 构造器中使用。

import { storeBindingsBehavior } from "mobx-miniprogram-bindings";
import { store } from "../../store/store";Component({behaviors: [storeBindingsBehavior],storeBindings: {store,fields: {numA: "numA",numB: "numB",sum: "sum",},actions: {updateNumA: "updateNumA",},},methods: {myMethod() {this.updateNumA()wx.nextTick(() => {const A = this.data.numA; // 3const B = this.data.numB; // 2const C = this.data.sum; // 5})},},
});

在 Page 页面中使用。

小程序基础库版本 2.9.2 以上,可以直接像 Component 构造器那样引入 behaviors 。

import { createStoreBindings } from "mobx-miniprogram-bindings";
import { store } from "../../store/store";Page({onLoad() {this.storeBindings = createStoreBindings(this, {store,fields: ["numA", "numB", "sum"],actions: ["updateNumA"],});wx.nextTick(() => {const A = this.data.numA; // 1const B = this.data.numB; // 2const C = this.data.sum; // 3})},onUnload() {this.storeBindings.destroyStoreBindings();},myMethod() {this.updateNumA()wx.nextTick(() => {const A = this.data.numA; // 3const B = this.data.numB; // 2const C = this.data.sum; // 5})},
})

相关内容

热门资讯

张晓风的这篇柳运用什么的修辞手... 张晓风的这篇柳运用什么的修辞手法张晓风的这片《柳》运用了比喻,对比的修辞手法。希望我的解答对我有帮助...
我想在手机上看童话书,请问在哪... 我想在手机上看童话书,请问在哪里找?我记得有类似的书,是不是一本红皮的?那个是有点类似杂志或者丛书的...
远古是一个怎样的世界 远古是一个怎样的世界漫漫四十多亿年哪,多长的时间呀,搞不好,以前主宰地球的物种的科技比我们还牛些的!...
有色没胆 有胆没色 有色没胆 有胆没色这两种男人有什么区别?哦这个.有色就是好色也不敢动手.有胆就是胆大不好色.或者是自...
华胥引中君伟的结局 华胥引中君伟的结局君玮最后是和苏仪在一起了。七七微段子里提到的慕言和阿拂家的孩子其实是君玮和苏仪的然...
带烁字的男孩名字 带烁字的男孩名字带烁字的男孩名字,用烁字起名烁(shuò):烁表示光亮、烁亮、烁烁。 繁体:烁;部首...
《披荆斩棘的哥哥》正在热播,看... 《披荆斩棘的哥哥》正在热播,看完这档节目后你有什么观后感?看完这档节目之后,我觉得挺好的,这次的节目...
我女儿的生辰八字:壬午年 丙... 我女儿的生辰八字:壬午年 丙午月 丙寅日 庚寅时 (2002年6月27日农历五月十七日早上...
点读机什么品牌好啊,怎么选啊? 点读机什么品牌好啊,怎么选啊?步步高点读机比较好,选大商场的正品,不要上网或电子市场买。
吴用只是个文弱书生,李逵为何会... 吴用只是个文弱书生,李逵为何会对他言听计从?尽管吴用只是一个文弱书生,但他对李逵忠心耿耿,所以李逵会...
开心星星球里甜心超人魔方玩了4... 开心星星球里甜心超人魔方玩了4秒是哪一集39集,新人。。。第四部《甜心超人的新爱好》
为什么会乐极生悲? 为什么会乐极生悲?从易经的观点看,任何事物都是相对立的。有生就有死,又高就有矮,有长久有段,同样,有...
一千零一夜中给国王讲故事的人是... 一千零一夜中给国王讲故事的人是谁山鲁佐德在《一千零一夜》中给萨桑王国国王讲故事的那位女性就是:萨桑王...
发生在别人身上是故事发生在自己... 发生在别人身上是故事发生在自己身上是事故是什么意思?这句话的意思是:友唯别人的经历或事件通常被视为故...
怎么判断一个人是否是精神病(狂... 怎么判断一个人是否是精神病(狂躁型)?看是不是很小很普通的事、甚至没有什么事,就大发脾气,做出各种过...
夜问丨天菩萨,“贵州省汤”竟然... 今日小暑,标志着盛夏的登场。这样的天气下,来上一口“贵州省汤”,你会不自觉感叹:天菩萨,怎么能这么鲜...
精酿“魔术师”沈高彬:让贵州风... 当精酿啤酒的醇厚撞上贵州风物的独特,会碰撞出怎样的味觉奇遇?在贵阳,曾是繁华都市调酒师的沈高彬,以匠...
有哪位朋友买过学而第一国学听读... 有哪位朋友买过学而第一国学听读机,好不好用是国内第一家做国学机的,产品,售后没得黑。国学机至今也有8...
女生说今天好热啊该怎么回复 女生说今天好热啊该怎么回复高情商回复如下:1、“你很热吗,那我给你讲个冷笑话中和一下吧,然后你就找个...
一家人过河的问题 一家人爸爸 ... 一家人过河的问题 一家人爸爸 妈妈 2儿子 2女儿 一个管家 一条狗爱因斯坦的智力题目得买7张票,宠...