redux-actions

其作用都是用来简化action、reducer。

1.安装

npm install --save redux-actions
// 或
yarn add redux-actions

2.使用

createAction

原来创建action:

const action = { type: START };

使用redux-actions创建action:

import { createAction } from 'redux-actions';
const action = createAction(START);
// 注:
  export const increment = createAction('INCREMENT')
  export const decrement = createAction('DECREMENT')
// 等于:
  increment() // { type: 'INCREMENT' }
  decrement() // { type: 'DECREMENT' }

handleActions

原来的reducer

function timer(state = defaultState, action) {
  switch (action.type) {
    case START:
      return { ...state, runStatus: true };
    case STOP:
      return { ...state, runStatus: false };
    case RESET:
      return { ...state, seconds: 0 };
    case RUN_TIMER:
      return { ...state, seconds: state.seconds + 1 };
    default:
      return state;
  }
}

使用 redux-actions 操作 state

const timer = handleActions(
  {
    START: (state, action) => ({ ...state, runStatus: true }),
    STOP: (state, action) => ({ ...state, runStatus: false }),
    RESET: (state, action) => ({ ...state, seconds: 0 }),
    RUN_TIMER: (state, action) => ({ ...state, seconds: state.seconds + 1 }),
  },
  defaultState
);

.

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值