網(wǎng)站首頁(yè) 編程語(yǔ)言 正文
一、安裝Redux Toolkit和React-Redux
注: “@reduxjs/toolkit”: “^1.8.6”, “react-redux”: “^8.0.4”
npm install @reduxjs/toolkit react-redux
二、創(chuàng)建Redux Store
從Redux Toolkit里引入configureStore,我們將從創(chuàng)建和導(dǎo)出一個(gè)空的Redux store開(kāi)始。
store/index.js
// 使用rtk來(lái)創(chuàng)建store
import { configureStore } from '@reduxjs/toolkit'
import useReducer from './userSlice'
/*
使用rtk的時(shí)候,reducer依然可以使用之前的創(chuàng)建不變
但是不再需要去合并reducer combineReducers
rtk提供了configureStore方法,直接接收一個(gè)對(duì)象作為參數(shù)
可以將reducer的相關(guān)配置直接通過(guò)這個(gè)對(duì)象進(jìn)行傳遞,不再需單獨(dú)合并reducer
reducer屬性可以直接單獨(dú)傳遞一個(gè)ruducer,也可以傳遞一個(gè)對(duì)象
*/
const store = configureStore({
reducer: {
user: useReducer
}
})
export default store
三、在React中使用Redux Store
我們就可以在src/index.js文件中用React-Redux提供的包裹我們的應(yīng)用,這樣我們就可以在React組件中使用React store了
具體操作就是先引入我們剛剛創(chuàng)建的Redux store,然后用包裹你的,再將store作為一個(gè)prop傳入。
src/index.js
import React from 'react'
import ReactDOM from 'react-dom/client'
import App from './App'
import { Provider } from 'react-redux'
import store from './store'
const root = ReactDOM.createRoot(document.getElementById('root'))
root.render(
<Provider store={store}>
<App />
</Provider>
)
四、創(chuàng)建一個(gè)Redux State Slice
slice需要一個(gè)name作為唯一標(biāo)識(shí),需要有初始化state值,還需要至少一個(gè)reducer方法來(lái)定義state如何變化。一旦slice創(chuàng)建完成我們就可以導(dǎo)出生成的Redux action creators和整個(gè)slice的reducer方法。
Redux需要我們通過(guò)制作數(shù)據(jù)副本和更新副本來(lái)不可變地更新state。然而Redux Toolkit的createSlice 和 createReducer API內(nèi)部使用了Immer,這允許我們可以直接寫更新邏輯,不必制作副本,它將自動(dòng)成為正確的不可變更新。
userSlice.js文件
// 切片對(duì)象
import { createSlice } from '@reduxjs/toolkit'
/*
reducer切片
createSlice函數(shù)的作用:生成分片的reducer
內(nèi)部調(diào)用的市createAction和createReducer
creatSlice可以幫助我們用更少的代碼去生成配套的reducer和action,而且有很好的維護(hù)性
*/
const userSlice = createSlice({
name: 'zhangsan', // 標(biāo)識(shí)符,生成actions的時(shí)候要使用,
// state初始值
initialState: {
name: '張三',
age: 18,
gender: '男'
} ,
// reducer的具體方法,
reducers: {
// 指定state的各種操作,直接就可以在對(duì)象中添加方法
setName(state, action) {
/*
可以通過(guò)不同的方法修來(lái)指定對(duì)state的不同的操作
state,action
可以直接修改state => state 是一個(gè)代理對(duì)象 之前的復(fù)制一份,返回一個(gè)新的對(duì)象
*/
state.name = action.payload
},
setAge(state, action) {
state.age = action.payload
}
}
})
/*
切片對(duì)象會(huì)自動(dòng)地幫助我們生成action
切片對(duì)象會(huì)根據(jù)我們地reducers方法來(lái)自動(dòng)地創(chuàng)建action對(duì)象,這些action對(duì)象會(huì)保存到切片對(duì)象的actions中
{type:name/函數(shù)名,payload:函數(shù)的參數(shù)}
*/
// 實(shí)際開(kāi)發(fā)中,setName,setAge對(duì)外暴露,
export const { setName, setAge } = userSlice.actions
export default userSlice.reducer
五、在React組件中使用Redux State和Action
現(xiàn)在我們可以使用React-Redux鉤子在React組件中操作Redux store。我們可以使用useSelector從store中讀取數(shù)據(jù),也可以使用useDispatch來(lái)dispatch actions。
src/App.js
import React from 'react'
import { useSelector, useDispatch } from 'react-redux'
import { setName, setAge } from './store/userSlice'
export default function App() {
const user = useSelector(state => state.user)
const dispatch = useDispatch()
const setNameHandler = () => {
dispatch(setName('李四'))
}
const setAgeHandler = () => {
dispatch(setAge(20))
}
return (
<div>
<h1>{user.name}</h1>
<h1>{user.age}</h1>
<h1>{user.gender}</h1>
<button onClick={setNameHandler}>修改name</button>
<button onClick={setAgeHandler}>修改年齡</button>
</div>
)
}
以上是關(guān)于如何在React中設(shè)置和使用 Redux Toolkit的簡(jiǎn)要概述。回顧細(xì)節(jié):
1、使用configureStore創(chuàng)建一個(gè)Redux Store
- configureStore接收reducer方法作為命名參數(shù),或者說(shuō)作為reducer對(duì)象的屬性
- configureStore會(huì)使用默認(rèn)設(shè)置自動(dòng)設(shè)置好store
2、在React組件中使用 Redux store
- 用React-Redux提供的 包裹你的
- 使用 傳入Redux store
3、使用createSlice創(chuàng)建Redux “slice” reducer
- createSlice需要有name屬性作為唯一標(biāo)識(shí),還需要初始化state和已命名的reducer方法
- Reducer方法通過(guò)使用Immer可以直接“改變”state,而不必手動(dòng)做副本
- 導(dǎo)出生成的slice reducer 和 action creators
4、在React組件中使用React-Redux的useSelector/useDispatch鉤子
- 使用useSelector鉤子從store中讀數(shù)據(jù)
- 使用useDispatch鉤子獲取到dispatch方法,并且根據(jù)需要dispatch actions
原文鏈接:https://blog.csdn.net/weixin_50636536/article/details/128357155
相關(guān)推薦
- 2022-11-26 React?數(shù)據(jù)獲取與性能優(yōu)化詳解_React
- 2022-08-16 Oracle數(shù)據(jù)庫(kù)事務(wù)的開(kāi)啟與結(jié)束詳解_oracle
- 2023-01-31 Android位圖(圖片)加載引入的內(nèi)存溢出問(wèn)題詳細(xì)解析_Android
- 2022-05-19 聊聊Python代碼中if?__name__?==?‘__main__‘的作用是什么_python
- 2022-10-08 ASP.NET堆和棧四之對(duì)托管和非托管資源的垃圾回收和內(nèi)存分配_實(shí)用技巧
- 2023-01-03 Android?自定義Livedata使用示例解析_Android
- 2022-04-19 8個(gè)實(shí)用的Python程序你知道幾個(gè)_python
- 2022-07-01 docker搭建mongodb單節(jié)點(diǎn)副本集的實(shí)現(xiàn)_docker
- 最近更新
-
- window11 系統(tǒng)安裝 yarn
- 超詳細(xì)win安裝深度學(xué)習(xí)環(huán)境2025年最新版(
- Linux 中運(yùn)行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲(chǔ)小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎(chǔ)操作-- 運(yùn)算符,流程控制 Flo
- 1. Int 和Integer 的區(qū)別,Jav
- spring @retryable不生效的一種
- Spring Security之認(rèn)證信息的處理
- Spring Security之認(rèn)證過(guò)濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權(quán)
- redisson分布式鎖中waittime的設(shè)
- maven:解決release錯(cuò)誤:Artif
- restTemplate使用總結(jié)
- Spring Security之安全異常處理
- MybatisPlus優(yōu)雅實(shí)現(xiàn)加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務(wù)發(fā)現(xiàn)-Nac
- Spring Security之基于HttpR
- Redis 底層數(shù)據(jù)結(jié)構(gòu)-簡(jiǎn)單動(dòng)態(tài)字符串(SD
- arthas操作spring被代理目標(biāo)對(duì)象命令
- Spring中的單例模式應(yīng)用詳解
- 聊聊消息隊(duì)列,發(fā)送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠(yuǎn)程分支