欢迎来到尧图网

客户服务 关于我们

您的位置:首页 > 新闻 > 国际 > react redux和@reduxjs/toolkit工具

react redux和@reduxjs/toolkit工具

2025/8/11 12:13:31 来源:https://blog.csdn.net/weixin_45561719/article/details/141423285  浏览:    关键词: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>

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com

热搜词