react——简化版redux:在一个文件中使用redux

//导入redux不能用ES6方式 import export
//使用commonjs方式
const redux=require('redux');
//初始化数据,它是放到reducer中使用
const initialState={
    counter:0
}
//创建reducer纯函数 第一个参数是state,可以用初始化值作为默认值,有了reducer创建store
function reducer(state=initialState,action){
    switch(action.type){
        case "INCREMENT":
            return {...state,counter:state.counter+1}
        case "DECREMENT":
            return {...state,counter:state.counter-1}
        case "ADD_NUM":
            return {...state,counter:state.counter+action.num}
        case "SUB_NUM":
            return {...state,counter:state.counter-action.num}
        default:
            return state;
    }
}
//创建store:store在创建的时候需要传入一个reducer
const store=redux.createStore(reducer)
//订阅监听counter的修改
store.subscribe(()=>{
    console.log("counter:",store.getState().counter)
})
//创建一个个actions
const action1={type:'INCREMENT'};
const action2={type:'DECREMENT'};
const action3={type:'ADD_NUM',num:5};
const action4={type:'SUB_NUM',num:12};
//派发action
store.dispatch(action1);
store.dispatch(action2);
store.dispatch(action3);
store.dispatch(action4);
//一旦开始执行派发dispatch,其内部就会去执行reducer函数,也就是通过store一旦派发了action,
//内部就会执行创建的reducer函数,执行reducer时候,会传入前一个state作为参数,
//第一次执行时候没有state值 可以使用默认值
//第二个参数就是派发的action 

//如何验证state确实作了修改呢?
//订阅store的修改
store.subscribe(()=>{
    console.log("state发生了改变")
})

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值