微信小程序中的全局数据共享(状态管理)使用介绍

开发工具:微信开发者工具Stable 1.06

一、状态管理简介

微信小程序全局状态是指可以在不同页面之间共享的数据或状态。

它可以存储用户的登录状态、个人信息、全局配置信息等。

二、安装MobX

1、安装NPM

在资源管理器的空白地方点右键,选择"在外部终端窗口中打开",注意要用管理员权限打开

输入 npm init -y

在"工具"一栏中选择"构建NPM"

2、安装MobX

步骤和上面一样,输入的代码改成下面这行:

npm install --save mobx-miniprogram@4.13.2 mobx-miniprogram-bindings@1.2.1

三、MobX简介

小程序中使用 mobx-miniprogrammobx-miniprogram-bindings 实现全局数据共享

mobx-miniprogram 用来创建store实例对象

mobx-miniprogram-bindings 用来把Store中的数据和方法,绑定到组件或页面中使用

四、MobX在页面中的使用

1、创建全局数据store

在根目录下创建store文件夹,在store文件夹里面创建store.js文件

javascript 复制代码
// 在这个 JS 文件中,专门来创建 Store 的实例对象

// 引入observable(存放数据), action(修改数据)
import { observable, action } from 'mobx-miniprogram'

// 创建store对象
export const store = observable({
  // 1 数据字段
  numA: 1,
  numB:2 ,
  // 2 计算属性
  get sum(){
    return this.numA + this.numB
  },
  // 3 action 方法,用来修改store中的数据
  // 普通页面中的方法不能修改这里的数据,方法要用 action() 包裹
  updateNum1:action(function(step){
    this.numA += step
  }),
  updateNum2:action(function(step){
    this.numB += step
  })
})

2、使用全局数据store

先在js页面中挂载store 交给this

javascript 复制代码
// 引入 操作全局数据的方法 createStoreBindings
// 引入 全局数据 store
import { createStoreBindings } from 'mobx-miniprogram-bindings'
import { store } from '../../store/store'

// 在onLoad 中加载全局数据,可以按需加载
  onLoad: function (options) {
    this.storeBindings = createStoreBindings(this,{
      store,
      fields:['numA','numB','sum'],
      actions: ['updateNum1']
    })
  },

// 在onUnload中做下销毁
  onUnload: function () {
    this.storeBindings.destroyStoreBindings()
  },

再在WXML页面中使用

数据的使用

数据直接就可以使用,同时找两个页面写上展示数据

html 复制代码
<view> {{numA}} + {{numB}} = {{sum}} </view>

方法的使用

传参: data-step="{{1}}" 调用: e.target.dataset.step

方法也可以直接使用

html 复制代码
<button bindtap="btnHandler1" data-step="{{1}}">numA + 1</button>
<button bindtap="btnHandler1" data-step="{{-1}}">numA - 1</button>
javascript 复制代码
 btnHandler1(e) {
    this.updateNum1(e.target.dataset.step)
  },

3、使用效果

在一个页面中修改全局数据,另一个页面的数据也会被修改

五、MobX在组件中的使用

1、创建全局数据store

这个和上面的一样

2、使用全局数据store

引入 storeBindingsBehavior 和store

用 behaviors 绑定引入的 storeBindingsBehavior

把数据源里的数据和方法都赋值过来

fields 的赋值用数组和对象都可以,actions也一样,用数组和对象都可以,用数组写起来简单点

javascript 复制代码
// components/numbers/numbers.js
import { storeBindingsBehavior } from 'mobx-miniprogram-bindings'
import { store } from '../../store/store'

Component({
  behaviors: [storeBindingsBehavior],
  storeBindings: {
    // 数据源
    store,
    fields: {
      numA: 'numA',
      numB: 'numB',
      sum: 'sum'
    },
    actions: {
      updateNum2: 'updateNum2'
    }
  }
  
})
相关推荐
黑云压城After44 分钟前
小程序(物流、快递),接入GPS北斗获取路线以及当前车辆位置
小程序
万岳科技程序员小金2 小时前
互联网医院系统源码解析:如何开发智能化的电子处方小程序?
小程序·app开发·互联网医院系统源码·智慧医疗小程序·医院app
Java Fans3 小时前
微信小程序——访问服务器媒体文件的实现步骤
服务器·微信小程序·小程序
Evaporator Core5 小时前
微信小程序数据绑定与事件处理:打造动态交互体验
微信小程序·小程序·交互
流烟默18 小时前
vue和微信小程序处理markdown格式数据
前端·vue.js·微信小程序
家里有只小肥猫21 小时前
uniApp小程序保存canvas图片
前端·小程序·uni-app
低代码布道师21 小时前
性格测评小程序10生成报告
低代码·小程序
科技小E21 小时前
EasyRTC:基于WebRTC与P2P技术,开启智能硬件音视频交互的全新时代
网络·网络协议·小程序·webrtc·p2p·智能硬件·视频监控
乔冠宇1 天前
微信小程序中将图片截图为正方形(自动居中)
微信小程序·小程序·typescript·uniapp
播播资源1 天前
ChatGPT付费创作系统V3.1.3独立版 WEB端+H5端+小程序端 (DeepSeek高级通道+推理输出格式)安装教程
前端·ai·chatgpt·ai作画·小程序·deepseek·deepseek-v3