【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'
			}
		})
	}

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

相关推荐
车厘小团子1 分钟前
📌 JS 高效生成数字数组:for 循环是最快的吗?最慢的方法竟然是它?
前端·javascript
怀男孩7 分钟前
ArkTS 基础语法
javascript·华为·harmonyos
blzlh23 分钟前
春招面试万字整理,全程拷打,干货满满(2)
前端·vue.js·面试
hollyhuang23 分钟前
div元素滚动,子元素出现跳动,怎么解决?
前端·css
崔璨28 分钟前
实现一个精简React -- 实现useEffect(10)
前端·react.js
Au_ust39 分钟前
React类的生命周期
前端·react.js·前端框架
Georgewu1 小时前
【HarmonyOS Next】鸿蒙中自定义弹框OpenCustomDialog、CustomDialog与DialogHub的区别详解
前端·华为·harmonyos
11在上班1 小时前
剖析initData在水合中的设计哲学
前端·设计模式
TitusTong1 小时前
使用 <think> 标签解析 DeepSeek 模型的推理过程
前端·ollama·deepseek