如何使用Redux Toolkit简化Redux

目录
  • 一、安装Redux Toolkit和React-Redux
  • 二、创建Redux Store
  • 三、在React中使用Redux Store
  • 四、创建一个Redux State Slice
  • 五、在React组件中使用Redux State和Action

一、安装Redux Toolkit和React-Redux

注: “@reduxjs/toolkit”: “^1.8.6”, “react-redux”: “^8.0.4”

npm install @reduxjs/toolkit react-redux

二、创建Redux Store

从Redux Toolkit里引入configureStore,我们将从创建和导出一个空的Redux store开始。

store/index.js
// 使用rtk来创建store
import { configureStore } from '@reduxjs/toolkit'
import useReducer from './userSlice'
/*
使用rtk的时候,reducer依然可以使用之前的创建不变
但是不再需要去合并reducer combineReducers
rtk提供了configureStore方法,直接接收一个对象作为参数
可以将reducer的相关配置直接通过这个对象进行传递,不再需单独合并reducer
reducer属性可以直接单独传递一个ruducer,也可以传递一个对象
*/
const store = configureStore({
  reducer: {
    user: useReducer
  }
})
export default store

三、在React中使用Redux Store

我们就可以在src/index.js文件中用React-Redux提供的包裹我们的应用,这样我们就可以在React组件中使用React store了

具体操作就是先引入我们刚刚创建的Redux store,然后用包裹你的,再将store作为一个prop传入。

src/index.js

import React from 'react'
import ReactDOM from 'react-dom/client'
import App from './App'
import { Provider } from 'react-redux'
import store from './store'
const root = ReactDOM.createRoot(document.getElementById('root'))
root.render(
  <Provider store={store}>
    <App />
  </Provider>
)

四、创建一个Redux State Slice

slice需要一个name作为唯一标识,需要有初始化state值,还需要至少一个reducer方法来定义state如何变化。一旦slice创建完成我们就可以导出生成的Redux action creators和整个slice的reducer方法。

Redux需要我们通过制作数据副本和更新副本来不可变地更新state。然而Redux Toolkit的createSlice 和 createReducer API内部使用了Immer,这允许我们可以直接写更新逻辑,不必制作副本,它将自动成为正确的不可变更新。

userSlice.js文件

// 切片对象
import { createSlice } from '@reduxjs/toolkit'
/*
reducer切片
createSlice函数的作用:生成分片的reducer
内部调用的市createAction和createReducer
creatSlice可以帮助我们用更少的代码去生成配套的reducer和action,而且有很好的维护性
*/
const userSlice = createSlice({
  name: 'zhangsan', // 标识符,生成actions的时候要使用,
  // state初始值
  initialState: {
    name: '张三',
    age: 18,
    gender: '男'
  } ,
  // reducer的具体方法,
  reducers: {
    // 指定state的各种操作,直接就可以在对象中添加方法
    setName(state, action) {
      /*
      可以通过不同的方法修来指定对state的不同的操作
      state,action
      可以直接修改state => state 是一个代理对象  之前的复制一份,返回一个新的对象
      */
      state.name = action.payload
    },
    setAge(state, action) {
      state.age = action.payload
    }
  }
})
/*
切片对象会自动地帮助我们生成action
切片对象会根据我们地reducers方法来自动地创建action对象,这些action对象会保存到切片对象的actions中
{type:name/函数名,payload:函数的参数}
*/
// 实际开发中,setName,setAge对外暴露,
export const { setName, setAge } = userSlice.actions
export default userSlice.reducer

五、在React组件中使用Redux State和Action

现在我们可以使用React-Redux钩子在React组件中操作Redux store。我们可以使用useSelector从store中读取数据,也可以使用useDispatch来dispatch actions。

src/App.js

import React from 'react'
import { useSelector, useDispatch } from 'react-redux'
import { setName, setAge } from './store/userSlice'
export default function App() {
  const user = useSelector(state => state.user)
  const dispatch = useDispatch()
  const setNameHandler = () => {
    dispatch(setName('李四'))
  }
  const setAgeHandler = () => {
    dispatch(setAge(20))
  }
  return (
    <div>
      <h1>{user.name}</h1>
      <h1>{user.age}</h1>
      <h1>{user.gender}</h1>
      <button onClick={setNameHandler}>修改name</button>
      <button onClick={setAgeHandler}>修改年龄</button>
    </div>
  )
}

以上是关于如何在React中设置和使用 Redux Toolkit的简要概述。回顾细节:

1、使用configureStore创建一个Redux Store

  • configureStore接收reducer方法作为命名参数,或者说作为reducer对象的属性
  • configureStore会使用默认设置自动设置好store

2、在React组件中使用 Redux store

  • 用React-Redux提供的 包裹你的
  • 使用 传入Redux store

3、使用createSlice创建Redux “slice” reducer

  • createSlice需要有name属性作为唯一标识,还需要初始化state和已命名的reducer方法
  • Reducer方法通过使用Immer可以直接“改变”state,而不必手动做副本
  • 导出生成的slice reducer 和 action creators

4、在React组件中使用React-Redux的useSelector/useDispatch钩子

  • 使用useSelector钩子从store中读数据
  • 使用useDispatch钩子获取到dispatch方法,并且根据需要dispatch actions

到此这篇关于如何使用Redux Toolkit简化Redux的文章就介绍到这了,更多相关Redux Toolkit内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • 如何使用Redux Toolkit简化Redux

    了解Redux Toolkit,这是用于高效Redux开发的经过验证的工具集.在本文中,你将看到为什么Redux Toolkit值得React社区更多的关注. React和Redux被认为是大规模React应用中管理状态的最佳组合.然而,随着时间的推移,Redux的受欢迎程度下降,原因是: 配置Redux Store并不简单. 我们需要几个软件包来使Redux与React一起工作. Redux需要太多样板代码. 带着这些问题,Redux的创建者Dan Abramov发表了名为<你可能不需要Red

  • React TypeScript 应用中便捷使用Redux Toolkit方法详解

    目录 前言 背景 Redux-Toolkit 常规使用 优化方案 优化 useDispatch 和 useSelector 优化修改 redux 状态的步骤 总结 前言 本文介绍的主要内容是 Redux-Toolkit 在 React + TypeScript 大型应用中的实践,主要解决的问题是使用 createSlice 的前提下消费 redux 状态仍旧有点繁琐的问题. 阅读本文需要的前置知识:了解 React .Redux-Toolkit .TypeScript 的使用. 关于 Redux

  • React immer与Redux Toolkit使用教程详解

    目录 1. immer 1.1 setState结合immer使用 1.2 useState结合immer使用 1.3 immer和redux集合 2. Redux Toolkit 1. immer 概述: 它和immutable相似的,实现了操作对象的数据共享,可以优化性能.它实现的原理使用es6的Proxy完成的.小巧,没有像immutable哪样有新数据类型,而是使用js类型. 安装: yarn add immer@9 1.1 setState结合immer使用 简单使用: import

  • Redux Toolkit的基本使用示例详解(Redux工具包)

    目录 Redux工具包的使用 Redux Toolkit介绍 Redux Toolkit基本使用 Redux工具包的使用 Redux Toolkit介绍 Redux Toolkit 是官方推荐的编写 Redux 逻辑的方法. 在前面我们学习Redux的时候应该已经发现,redux的编写逻辑过于的繁琐和麻烦. 并且代码通常分拆在多个文件中(虽然也可以放到一个文件管理,但是代码量过多,不利于管理); Redux Toolkit包旨在成为编写Redux逻辑的标准方式,从而解决上面提到的问题; 在很多地

  • React 中使用 Redux 的 4 种写法小结

    目录 不使用 Redux 的写法 最底层的写法 React-Redux React-Redux 配合 connect 高阶组件 React-Rudex 配合 React Hooks Redux Toolkit 总结 Redux 是一种状态容器 JS 库,提供可预测的状态管理,经常和 React 配合来管理应用的全局状态,进行响应式组件更新. Redux 一般来说并不是必须的,只有在项目比较复杂的时候,比如多个分散在不同地方的组件使用同一个状态.对于这种情况,如果通过 props 层层传递,代码会

  • React Redux应用示例详解

    目录 一 React-Redux的应用 1.学习文档 2.Redux的需求 3.什么是Redux 4.什么情况下需要使用redux 二.最新React-Redux 的流程 安装Redux Toolkit 创建一个 React Redux 应用 基础示例 Redux Toolkit 示例 三.使用教程 安装Redux Toolkit和React-Redux​ 创建 Redux Store​ 为React提供Redux Store​ 创建Redux State Slice​ 将Slice Reduc

  • 你可能不需要在JavaScript使用switch语句

    没有 switch 就没有复杂的代码块 switch很方便:给定一个表达式,我们可以检查它是否与一堆case子句中的其他表达式匹配. 考虑以下示例: const name = "Juliana"; switch (name) { case "Juliana": console.log("She's Juliana"); break; case "Tom": console.log("She's not Juliana

  • 使用react+redux实现计数器功能及遇到问题

    Redux,本身就是一个单纯的状态管理者,我们不追溯它的历史,从使用角度来说:它提供一个全局的对象store,store中包含state对象用以包含所有应用数据,并且store提供了一些reducer方法.这些方法可以自定义,使用调用者得以改变state的值.state的值仅为只读,如果需要更改则必须只能通过reducer. Redux 核心对象:store 数据存储:state 状态更新提交接口:==dispatch== 状态更新提交参数:带type和payload的==Action== 状态

  • 详解JavaScript状态容器Redux

    目录 一.Why Redux 二.Redux Data flow 三.Three Principles(三大原则) 四.Redux源码解析 4.1.index.js 4.2.createStore.js 4.3.combineReducers.js 4.4.bindActionCreators.js 4.5.compose.js 4.6.applyMiddleware.js 五.从零开始实现一个简单的Redux 六.Redux Devtools 七.总结 一.Why Redux 在说为什么用 R

  • redux工作原理讲解及使用方法

    目录 1. redux 是什么? 2.redux的原理 3. 如何使用 redux? (1).安装redux,创建redux文件夹,建立store.js (2).建立reducers.js (3).引入store.subscribe (4). 引入react-redux 1. redux 是什么? React 只是 DOM 的一个抽象层,并不是 Web 应用的完整解决方案.react只是一个轻量级的视图层框架,如果要做大型应用就要搭配视图层框架redux一起使用.主要引用于多交互.多数据源的场景

随机推荐