react中使用redux最简单最方便的方式,配合rematch简化操作,5分钟学会

news/2024/7/15 19:16:39 标签: react.js, 前端, javascript

react中使用状态管理的方式也很多,比如redux和mobx等,今天这一片就讲一下redux的入门到熟练使用,主要是要理解它redux的组成有哪些,到怎么创建,和组建中怎么使用三个问题。这里先放上官网文档,不理解的地方可以看看官方文档:

redux官方文档:Redux 中文文档 · Redux

rematch文档:Installation | Rematch

第一步,创建一个简单的react项目

我这里使用vite直接创建了一个最简单的react项目,vite相比webpack还是简单了,vite官网:开始 | Vite 官方中文文档。 使用命令:

npm create vite

然后输入项目名和选择的框架等就可以了: 

开始 | Vite 官方中文文档。 使用命令:

第二步,安装redux和相关依赖

安装redux和react-redux:

npm install --save redux

// 依赖包
npm install --save react-redux

安装@rematch/corn:

npm install @rematch/core

第三步,创建store和使用store

在项目目录下面创建一个store文件夹,然后管理状态:

创建store的前提是先创建有model,model是管理不同的数据状态的最小模块 ,比如user,game,good等不同的模块存储不同的数据状态。model长什么样呢?里面的name,state,reducers,effets都是干什么的呢?

  • state:

    • 存放模块状态的地方。
  • reducers:

    • 改变store状态的地方,每个reducers函数都会返回一个对象作为模块最新的state。
    • reducers中的函数必须为同步函数,如果要异步处理数据需要在effects中处理。
    • 注意:只能通过在reducers的函数中通过返回一个新的对象来改变模块中state的值,直接通过修改state的方式是是不能改变模块的state的值。例:
          increment(state, num1) {  
              state.num = num1  // 这样的写法是错误的
          },
    
  • effects:

    • 处理异步数据的地方,比如:异步从服务端获取数据。
    • 注意:在effects中是不能修改模块的state,需要在异步处理完数据后调用reducers中的函数修改模块的state。
  • rematch的state、reducers、effects和vuex的state、mutaition、action用法非常相似,在vuex中mutation修改model的state的值,action进行异步处理数据。

下面是一个我写的用户模块:

javascript">export default {
  // model名字
  name: 'user',
  // 默认初始状态
  state: {
    userName: '用户名',
    age: 0
  },
  reducers: {
    setUser(state: any, name: any, age: any) {
      return {
        ...state,
        userName: name,
        age: age
      }
    }
  },
  effects: (dispatch: any) => ({
    async getInfoAsync(userId: any, rootState: any) {
      //   模拟调用服务器数据
      console.log('用户信息', userId, rootState)
      //   模拟服务器请求两秒后
      await new Promise((resolve) => setTimeout(resolve, 2000))
      // 使用this.调用的方式:ts会报错的,所以推荐使用下面的dispatch调用
      // this.increment()
      // 使用dispatch调用
      dispatch.user.setUser('王思聪', 38)
    }
  })
}

有了model,就可以创建store了,store怎么创建呢?里面的models是干什么的呢?

初始化store的时候rematch支持传入多个模块,在中、大型项目中可以根据业务的需要,拆分成多个模块,这样项目的结果就会变得清晰明了,所以store里面的models可以存储好多个模块:

javascript">import { init } from '@rematch/core'
import user from './user'

const store = init({
  models: {
    user
  }
})

export default store

最后还需要将store挂载到App根节点上:这样下面的所有子组件就可以使用store了

 

第四步,组建中使用和修改store状态

在子组件中使用store的方式:使用hooks的方式会很方便

javascript">import { useSelector, useDispatch } from 'react-redux'
import './App.css'

function App() {
  // 使用hooks的方式引用数据和修改数据:user就是不同的模块
  const userStore = useSelector((state: any) => state.user)
  const dispatch = useDispatch().user

  const setUser = () => {
    console.log('修改用户名', dispatch)
    // 调用异步函数修改
    dispatch.getInfoAsync('123')
  }

  return (
    <>
      <div className='app-main'>
        <div>
          <span>用户名:</span>
          {userStore.userName}
        </div>
        <div>
          <span>年龄:</span>
          {userStore.age}
        </div>
        {/* 点击修改年龄 */}
        <div>
          <button onClick={setUser}>修改store信息</button>
        </div>
      </div>
    </>
  )
}

export default App

第五步,安装redux-devtools协助开发

使用redux-devtools可以很方便的管理和查看redux里面的数据结构和状态:

 

redux总结 

省略了action types

不必再多次写字符串,使用model/method代替

省略了action creators

直接调用方法,不必再生产action type(原版dispatch方法返回{type, payload}),使用dispatch.model.method代替

省略了switch语句

调用model.method方法,不必判断action type ( 原本reduces中)

集中书写状态,同步和异步方法

在一个model中使用state,reducers和effects来写状态,同步和异步方法


http://www.niftyadmin.cn/n/5283766.html

相关文章

【FPGA】分享一些FPGA协同MATLAB开发的书籍

在做FPGA工程师的这些年&#xff0c;买过好多书&#xff0c;也看过好多书&#xff0c;分享一下。 后续会慢慢的补充书评。 【FPGA】分享一些FPGA入门学习的书籍【FPGA】分享一些FPGA协同MATLAB开发的书籍 【FPGA】分享一些FPGA视频图像处理相关的书籍 【FPGA】分享一些FPGA高速…

【MyBatis-Plus】分页查询

为什么&#xff1f; 使用分页查询&#xff0c;可以将查询结果分割成多个部分&#xff0c;每次只查询部分数据&#xff0c;从而提高性能、减少内存消耗、提高用户体验和数据安全性。 封装分页查询数据类 分页查询的结果通常包含 4 个字段&#xff1a; page&#xff1a;当前页…

Javacv-利用Netty实现推流直播复用(flv)

前言 上一篇文章《JavaCV之rtmp推流&#xff08;FLV和M3U8&#xff09;》介绍了javacv的基本使用&#xff0c;今天来讲讲如何实现推流复用。 以监控摄像头的直播为例&#xff0c;通常分为三步&#xff1a; 从设备获取音视频流利用javacv进行解码&#xff08;例如flv或m3u8&am…

Python时间复杂度计算题答案

评论 题目链接 https://blog.csdn.net/qq_33254766/article/details/132255078 答案 时间复杂度&#xff1a;O(n)。 分析&#xff1a;这段代码遍历了n次&#xff0c;所以时间复杂度是线性的&#xff0c;即O(n)。 时间复杂度&#xff1a;O(n^2)。 分析&#xff1a;两个嵌套的…

《计算机网络管理》第四章 管理信息库思维导图

文章目录 总览4.1 MIB简介4.2 MIB-2功能组系统组接口组地址转换组IP组Icmp组Tcp组Udp组Egp组传输组 4.3 MIB-2的局限性4.4 小结 总览 4.1 MIB简介 4.2 MIB-2功能组 系统组 接口组 地址转换组 IP组 Icmp组 Tcp组 Udp组 Egp组 传输组 4.3 MIB-2的局限性 4.4 小结

Spring Boot实践指南

一.SpringBoot入门案例 SpringBoot是由Pivotal团队提供的全新框架&#xff0c;其设计目的是用来简化Spring应用的初始搭建以及开发过程 原生开发SpringMVC程序过程 在没有SpringBoot前&#xff1a; 1.入门案例开发步骤 &#xff08;1&#xff09;创建新模块&#xff0c;选…

探秘JDK 13的黑科技:新特性一览

欢迎来到我的博客&#xff0c;代码的世界里&#xff0c;每一行都是一个故事 探秘JDK 13的黑科技&#xff1a;新特性一览 前言switch表达式扩展Switch表达式的基本概念&#xff1a;使用Switch表达式的优势&#xff1a;示例代码&#xff1a;注意事项和最佳实践&#xff1a; Text …

【并发编程篇】定义最大线程的方法

文章目录 &#x1f354;省流&#x1f3f3;️‍&#x1f308;前言&#x1f6f8;CPU密集型&#x1f339;代码实现 &#x1f6f8;IO密集型 &#x1f354;省流 池的最大大小如何去设置 使用CPU密集型和IO密集型这2种方法 &#x1f3f3;️‍&#x1f308;前言 上一篇文章我们讲解…