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

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

相关推荐
xiaoyustudiowww1 天前
fetch异步简单版本(Tomcat 9)
java·前端·tomcat
TOPGUS1 天前
谷歌Chrome浏览器即将对HTTP网站设卡:突出展示“始终使用安全连接”功能
前端·网络·chrome·http·搜索引擎·seo·数字营销
C_心欲无痕1 天前
ts - 模板字面量类型与 `keyof` 的魔法组合:`keyof T & `on${string}`使用
linux·运维·开发语言·前端·ubuntu·typescript
Van_captain1 天前
rn_for_openharmony常用组件_Tabs选项卡
javascript·开源·harmonyos
赵民勇1 天前
ES6中的const用法详解
javascript·es6
一勺菠萝丶1 天前
Java 后端想学 Vue,又想写浏览器插件?
java·前端·vue.js
@PHARAOH1 天前
HOW - 如何禁用 localstorage
前端·状态模式
霍理迪1 天前
CSS布局方式——弹性盒子(flex)
前端·css
Van_captain1 天前
React Native for OpenHarmony Toast 轻提示组件:自动消失的操作反馈
javascript·开源·harmonyos
Van_captain1 天前
React Native for OpenHarmony Modal 模态框组件:阻断式交互的设计与实现
javascript·开源·harmonyos