【React】使用reduxjs/toolkit进行状态管理

在我们的项目中通常需要维护一个状态管理器来支持我们进行跨组件的数据通讯,react生态提供了reduxjs/toolkit 来进行状态管理

首先我们安装一下必要的依赖

javascript 复制代码
npm install react-redux @reduxjs/toolkit

接下来在我们的工程项目的src同级目录里面新建文件夹store

文件夹内新建index.jsuserStore.js 文件
userStore文件:

javascript 复制代码
import { createSlice } from "@reduxjs/toolkit";

const initialState = {
  userName: '',
  token: '',  
}

export const userSlice = createSlice({
  name: "user",
  initialState,
  reducers: {
    setUser: (state, action) => {
      state.userName = action.payload.userName;
      state.token = action.payload.token;
    },
    removeUser: (state) => {
      state.user = null;
      state.token = null;
    },
  },
});

export const { setUser, removeUser } = userSlice.actions;

export default userSlice.reducer;

index.js文件

javascript 复制代码
import { configureStore } from '@reduxjs/toolkit';
import userReducer from './userStore';

export const store =  configureStore({
    reducer: {
        user: userReducer
    }
});

项目入口文件index.js

javascript 复制代码
import App from './App'
import { Provider } from 'react-redux';
import { store } from './store/index';

const root = ReactDOM.createRoot(document.getElementById('root'))

root.render(
    <React.StrictMode>
        <Provider store={store}>
            <App />
        </Provider>
    </React.StrictMode>
)

在组件中使用:

javascript 复制代码
const userName = useSelector(state => state.user.userName);
const dispatch = useDispatch();
const setUserInfo = ()=>{
		dispatch({
			type: 'user/setUser',
			payload: {
				userName: 'admin',
				token:'6666666'
			}
		})
	}

这样,一个简单的状态管理配置就完成了!

相关推荐
x-cmd10 分钟前
[250512] Node.js 24 发布:ClangCL 构建,升级 V8 引擎、集成 npm 11
前端·javascript·windows·npm·node.js
夏之小星星23 分钟前
el-tree结合checkbox实现数据回显
前端·javascript·vue.js
crazyme_637 分钟前
前端自学入门:HTML 基础详解与学习路线指引
前端·学习·html
撸猫7911 小时前
HttpSession 的运行原理
前端·后端·cookie·httpsession
亦世凡华、1 小时前
Rollup入门与进阶:为现代Web应用构建超小的打包文件
前端·经验分享·rollup·配置项目·前端分享
Bl_a_ck2 小时前
【React】Craco 简介
开发语言·前端·react.js·typescript·前端框架
为美好的生活献上中指2 小时前
java每日精进 5.11【WebSocket】
java·javascript·css·网络·sql·websocket·网络协议
augenstern4162 小时前
webpack重构优化
前端·webpack·重构
海拥✘3 小时前
CodeBuddy终极测评:中国版Cursor的开发革命(含安装指南+HTML游戏实战)
前端·游戏·html
寧笙(Lycode)3 小时前
React系列——HOC高阶组件的封装与使用
前端·react.js·前端框架