react学习-redux

redux

Redux要求我们通过action来更新数据:

  1. 所有数据的变化,必须通过派发(dispatch)action来更新;
  2. action是一个普通的JavaScript对象,用来描述这次更新的type和content

在这里插入图片描述 reducer是一个纯函数;
reducer做的事情就是将传入的state和action结合起来生成一个新的state;

eg:

const redux=require('redux')

const initialState={
    counter:0
}

//reducer
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_NUMBER':
             return{...state,counter:state.counter+action.num}
          case 'SUB_NUMBER':
                return{...state,counter:state.counter-action.num}
     }
}

//store
const store=redux.createStore(reducer)

//订阅store的修改
store.subscribe(()=>{
    console.log('counter:'+store.getState().counter)
})

//actions
const action1={type:'INCREMENT'};
const action2={type:'DECREMENT'};
const action3={type:'ADD_NUMBER',num:6};
const action4={type:'SUB_NUMBER',num:5};



//派发actions
store.dispatch(action1)
store.dispatch(action2)
store.dispatch(action3)
store.dispatch(action4)

在这里插入图片描述

在这里插入图片描述
开发中常用结构
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
使用时
在这里插入图片描述在react过程中的使用
在这里插入图片描述

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值