微信小程序API的Promise化及全局状态管理MobX

文章介绍了如何将微信小程序的API转换为Promise形式以避免回调地狱,推荐使用miniprogram-api-promise库。同时,文章讲解了利用mobx-miniprogram和mobx-miniprogram-bindings在小程序中实现全局状态管理,创建store实例并绑定到页面和组件中,以便于数据共享和更新。
摘要由CSDN通过智能技术生成

API的Promise化

默认情况下小程序官方提供的API都是基于回调函数实现的,例如

wx.request({
	method:'',
	url:'',
	data:{},
	success:()=>{},
	fail: ()=>{},
	complete: ()=>{}
})

为了避免回调地狱的问题,我们将小程序的API Promise化

小程序中的Promise主要依赖于miniprogram-api-promise三方npm包

每次装完新包要记得重新构建npm,同时建议重新构建前先删除miniprogram_npm这个文件

创建promise化的对象
// app.js
import {promisifyAll} from 'miniprogram-api-promise'
// 创建wxp和wx.p用于存放封装好的api
const wxp = wx.p = {}
promisifyAll(wx,wxp)

全局状态管理

即解决组件之间数据共享的问题,常用的全局共享解决方案有:Vuex、Redux、MobX等

在小程序中,我们使用mobx-miniprogram配合mobx-miniprogram-bindings实现全局数据共享

  • mobx-miniprogram用于创建store实例对象
  • mobx-miniprogram-bindings用于将store中的共享数据或方法,绑定到组件或页面中使用
npm i --save mobx-miniprogram@4.13.2 mobx-miniprogram-bindings@1.2.1
创建

在根目录创建store文件夹,内部含store.js

// 该文件用于创建store实例
import {action, observable} from 'mobx-miniprogram'

export const store = observable({
  // 数据字段
  numA: 1,
  numB: 2,
  // 计算属性
  get sum(){
    return this.numA + this.numB
  },
  // actions
  updateNumA: action(function(step){
    this.numA += step
  })
})
页面中绑定
  1. 导入
  2. onLoad周期进行绑定
  3. onUnload周期进行清理
import {createStoreBindings} from 'mobx-miniprogram-bindings'
import {store} from '../../store/store'

onLoad: function (options) {
  // createStoreBindings(实例,配置对象)
  // 配置对象:store数据源;fields数据;actions方法
  this.storeBindings = createStoreBindings(this,{
    store,
    fields:['numA','numB','sum'],
    actions:['updateNumA']
  })
},
onUnload: function () {
  this.storeBindings.destroyStoreBindings()
},
页面中使用
<view>{{numA}} + {{numB}} = {{sum}}</view>
<van-button type="primary" bindtap="btnClick" data-step="{{1}}"> numA+1 </van-button>
<van-button type="danger" bindtap="btnClick" data-step="{{-1}}"> numA-1 </van-button>
btnClick(e){
  this.updateNumA(e.target.dataset.step)
},
组件中绑定
import { storeBindingsBehavior } from 'mobx-miniprogram-bindings'
import { store } from '../../store/store'

Component({
  // 自动绑定
  behaviors:[storeBindingsBehavior],
  storeBindings:{
    store,
    fields:{
      numA: ()=> store.numA, // 绑定字段第一种方式
      numB: (store)=>store.numB, // 绑定字段第二种方式
      sum:'sum' // 绑定字段第三种方式
    },
    actions:{
      updateNumB:"updateNumB"
    }
  }
})
组件中使用

同页面的使用方法

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

会飞的战斗鸡

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值