当前位置: 首页 > news >正文

react redux和@reduxjs/toolkit工具

1,安装

npm i @reduxjs/toolkit react-redux

2,目录

  • store
    • modules
      • counterStore.js
    • index.js

3,最外层index.js引入

import store from './store'
import { Provider } from 'react-redux'<Provider store={store}><App /></Provider>

4,编写counterStore.js

import { createSlice } from "@reduxjs/toolkit"const counterStore = createSlice({name: 'counter',// 初始化stateinitialState: {count: 0},// 修改状态的方法 同步方法 支持直接修改reducers: {inscrement (state) {state.count++},decrement (state) {state.count--}}
})// 解构出来actionCreate函数
const { inscrement, decrement } = counterStore.actions// 获取reducer
const reducer = counterStore.reducer// 以按需的方式导出actionCreate
export { inscrement, decrement }// 以默认导出方式导出reducer
export default reducer

5,store/index.js引入子模块

import { configureStore } from "@reduxjs/toolkit"
// 导入子模块reducer
import counterReducer from "./modules/counterStore"const store = configureStore({reducer: {counter: counterReducer}
})export default store

6,相应文件调用

import { useSelector, useDispatch } from "react-redux"
// 导入创建action对象的方法
import { inscrement, decrement } from "./store/modules/counterStore"function App () {// 这里的state.counter的counter与store/index.js下的counter相对应const { count } = useSelector(state => state.counter)// 得到dispatch函数const dispatch = useDispatch()return (<div className="App">{/* 调用dispatch提交action对象 */}<button onClick={() => dispatch(inscrement())}>++</button>{count}<button onClick={() => dispatch(decrement())}>--</button></div>)
}export default App

7,提交action传参实现需求
在reducers的同步修改方法中添加action对象参数,在调用actionCreater的时候传递参数,参数会被传递到action对象payload属性上

// counterStore.jsreducers: {// 传参addToNumber (state, action) {state.count = action.payload}}// 添加addToNumber
const { addToNumber } = counterStore.actions
export { addToNumber }

使用

import { addToNumber } from "./store/modules/counterStore"
<button onClick={() => dispatch(addToNumber(10))}>to 10</button>

相关文章:

  • 北京网站建设多少钱?
  • 辽宁网页制作哪家好_网站建设
  • 高端品牌网站建设_汉中网站制作
  • SpringBoot集成kafka-监听器注解
  • 知识图谱问答召回机制-GraphRAG
  • “领导让我帮忙买30杯奶茶,实际花费535元,但领导却只转了500元,我该如何提醒领导转我35元的差额?”
  • 【全开源】php在线客服系统源码 (搭建教程+全新UI)
  • 如何上传NPM包:一步步指南
  • Linux磁盘操作之df命令
  • 利用Pandas的groupby和矢量化运算,减少显式循环,提高处理速度
  • 如何有效激活微信陌生客户:加好友后的沟通策略!
  • 滴滴出行:分布式数据库的架构演进之路|OceanBase案例
  • 【机器学习】线性回归
  • 汇川技术|Inoproshop软件菜单[在线、调试]
  • 如何高质量将PDF拆分多个文件?这6款工具超好用
  • 汽车DV与PV测试
  • SuperMap WebGPA外部大数据集群部署实践
  • 动手学深度学习课程竞赛:Classify Leaves
  • iOS编译提示和导航提示
  • Java 内存分配及垃圾回收机制初探
  • PhantomJS 安装
  • PyCharm搭建GO开发环境(GO语言学习第1课)
  • Sass 快速入门教程
  • Tornado学习笔记(1)
  • Vue UI框架库开发介绍
  • vue脚手架vue-cli
  • Xmanager 远程桌面 CentOS 7
  • 极限编程 (Extreme Programming) - 发布计划 (Release Planning)
  • 前端设计模式
  • 浅析微信支付:申请退款、退款回调接口、查询退款
  • 如何将自己的网站分享到QQ空间,微信,微博等等
  • 如何用Ubuntu和Xen来设置Kubernetes?
  • 实现菜单下拉伸展折叠效果demo
  • 适配iPhoneX、iPhoneXs、iPhoneXs Max、iPhoneXr 屏幕尺寸及安全区域
  • 一道闭包题引发的思考
  • 用 vue 组件自定义 v-model, 实现一个 Tab 组件。
  • 容器镜像
  • ​Benvista PhotoZoom Pro 9.0.4新功能介绍
  • ​Spring Boot 分片上传文件
  • ### RabbitMQ五种工作模式:
  • #include
  • #nginx配置案例
  • $().each和$.each的区别
  • (4)事件处理——(7)简单事件(Simple events)
  • (9)STL算法之逆转旋转
  • (Mirage系列之二)VMware Horizon Mirage的经典用户用例及真实案例分析
  • (编程语言界的丐帮 C#).NET MD5 HASH 哈希 加密 与JAVA 互通
  • (代码示例)使用setTimeout来延迟加载JS脚本文件
  • (原創) 如何將struct塞進vector? (C/C++) (STL)
  • . ./ bash dash source 这五种执行shell脚本方式 区别
  • .DFS.
  • .net 8 发布了,试下微软最近强推的MAUI
  • .Net Attribute详解(上)-Attribute本质以及一个简单示例
  • .net core 控制台应用程序读取配置文件app.config
  • .NET Framework 服务实现监控可观测性最佳实践
  • .NET MAUI Sqlite数据库操作(二)异步初始化方法
  • .pyc文件是什么?
  • @Transactional 参数详解