轻松掌握 Redux 核心用法

本文已收录在 Github: https://github.com/beichensky/Blog 中,欢迎 Star!

写在前面

本文代码通过 create-react-app 脚手架进行搭建,所有的代码均可直接复制运行。

代码位置:react-redux-demo

本文主要讲解了 Redux 和 React-Redux 的使用,详细的概念以及设计思想请看 Redux 中文官网

# npx
npx create-react-app my-app

# npm
npm init react-app my-app

# yarn
yarn create react-app my-app
  • 安装 redux
npm install redux
# or
yarn add redux

一、Action 描述更新对象

是把数据从组件传到 store 的载体,是修改 store 数据的唯一来源。
是一个普通的 javascript 对象,必须包含一个 type 属性,用来通知 reducer 这个 action 需要做的操作类型。
比如:

{
   
    type: 'ADD',
    payload: 1
}

通过 store.dispatch(action)action 传给 store

二、Reducer 执行更新函数

描述 store 数据如何更新的纯函数,接受两个参数

  • statestore 中的 state 值,可以给 state 设置初始值

  • action:通过 store.dispatch(action) 传递的 action 对象

通过 actiontype 类型来判断如何更新 state 数据

比如:

function reducer(state = 0, {
    type, payload }) {
   
  switch (type) {
   
    case "ADD":
      return state + payload;
    case "DELETE":
      return state - payload;
    default:
      return state;
  }
}

三、Store

actionreducer 联系到一起的对象,具有以下职责

  • 维持应用的 state
  • 提供 getState() 方法获取 state
  • 提供 dispatch(action) 方法更新 state
  • 通过 subscribe(listener) 注册监听器;
  • 通过 subscribe(listener) 返回的函数注销监听器

store 的创建方式

const store = createStore(reducer[, prevState, ehancer]);

四、实现一个简单的 React 计数器

  • 通过 store.dispatch(action) 通知数据更新
  • 通过 store 获取 state 数据
  • 编写 reducer 实现数据更新

store/index.js

import {
    createStore } from "redux";

// 创建 reducer 函数 ,更新 state 数据
const reducer = function(state = 0, {
    type }) {
   
  switch (type) {
   
    case "INCREMENT":
      return ++state;
    case "DECREMENT":
      return --state;
    default:
      return state;
  }
};

// 创建 store
const store 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值