import {init,dispatch} from ‘rematch/core’;
const count = {
state:{
number:0
},
reducers:{//一个改变该model state的所有函数的对象
increments:(state,payload) => state.number + payload,
decrements:(state,payload) => state.number – payload,
},
effects:{//方法都写在这里
async asyncIncrements(payload){//异步增加
await this.increments(payload);
},
async asyncDecrements(payload){
await this.decrements(payload);
}
}
}
const store = init({
models:{count},
redux:{}
})
dispatch.count.asyncIncrements(10);//异步增加10
dispatch.count.asyncDecrements(10);//异步减少10
使用:
import React from ‘react’
import {connect} from ‘react-redux’
class App extends Component{
addCount = (value)=>{//异步增加数据
const { CountDispatch } = this.props;
CountDispatch.asyncIncrements(value);
}
cutCount = (value) =>{//异步减少数据
const {CountDispatch} = this.props;
CountDispatch.asyncIncrements(value);
}
render(){
let {CountNumbers} = this.props;
return (
<div>
<p>获取count数据中的number变化:{CountNumbers.number}</p>
<input type=”button” value=”增加数据” onClick={this.addCount(10)}/>
<input type=”button” value=”减少数据” onClick={this.cutCount(10)}/>
</div>
)
}
}
const mapStateToProps =(state)=>{
CountNumbers:state.count,//获取count数据
}
const mapDispatchToProps=(dispatch)=>{
CountDispatch:dispatch.count,//获取count方法
}
export default connect(mapStateToProps,mapDispatchToProps)(App)
今天的文章repatch怎么用_fetch方法[通俗易懂]分享到此就结束了,感谢您的阅读。
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
如需转载请保留出处:https://bianchenghao.cn/71660.html