Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/lbqdly/mobx-wxapp
在小程序中使用mobx
https://github.com/lbqdly/mobx-wxapp
connect miniprogram mobx mobx-react weapp wechat wxapp
Last synced: 2 months ago
JSON representation
在小程序中使用mobx
- Host: GitHub
- URL: https://github.com/lbqdly/mobx-wxapp
- Owner: lbqdly
- Created: 2018-04-07T10:13:59.000Z (almost 7 years ago)
- Default Branch: master
- Last Pushed: 2019-05-27T03:12:23.000Z (over 5 years ago)
- Last Synced: 2024-05-09T15:43:52.406Z (8 months ago)
- Topics: connect, miniprogram, mobx, mobx-react, weapp, wechat, wxapp
- Language: JavaScript
- Homepage:
- Size: 133 KB
- Stars: 56
- Watchers: 6
- Forks: 10
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
- awesome-state - mobx-wxapp
README
# mobx-wxapp
在小程序中使用[mobx](https://github.com/mobxjs/mobx),`connect`函数可将被观察的数据高效的绑定到小程序视图。
旧的`inject`方式见[v1](https://github.com/b5156/mobx-wxapp/tree/v1)### 安装
`npm install mobx-wxapp` 安装项目到本地 或 直接拷贝文件(example/mobx-wxapp.js)到您的项目。
(案例使用了 mobx.js v4.6.0 ,因 mobx5 使用了小程序暂不支持的 ES6 proxy)
### 用法
pages/index.js:
```JavaScript
import { connect, extract } from '../mobx-wxapp'
import { observable } from '../mobx'const appStore = observable({
title: 'mobx-wxapp'
})const store = observable({
// observable
seconds: 0,// computed
get color() {
return this.seconds % 2 ? 'red' : 'green'
},// actions
tick() {
this.seconds += 1
}
})// page
Page({
onLoad() {
connect(this, () => ({
title: appStore.title,
color: store.color,
seconds: store.seconds
// 或者使用 extract 一次性提取全部属性
// ...extract(store)
})
)
},
add() {
store.tick()
}
})```
pages/index.wxml:```xml
{{ title }} :
seconds:{{ seconds }}
add
```当然,您也可在 Component 中使用:
```JavaScript
Component({
//..
ready(){
this.disposer = connect(this,mapDataToStore,options)
},//请务必在组件生命周期结束前执行销毁器!
detached(){
this.disposer();
}
//...
})
```## API
### connect(context,mapDataToStore,options?)
+ context:Object // 请传入this
+ mapDataToStore:Function //需要绑定到视图的映射函数
+ options:Object // 可选参数```
options = {
delay:Number,// setData的最小执行间隔,默认30ms
setDataCallback:Function // setData的执行回调
}
```
返回值:`connect`返回一个销毁器函数(在 Page 中使用时将自动在 onUnload 生命周期执行,但在 Component 构造器中使用时请确保在生命周期结束时手动调用此函数)。### extract(store)
映射整个store的快捷方式
+ store:Object // 一个被观察的store对象返回值:一个可被映射到data的对象
## 应用
## License
ISC licensed.