如何使用Redux Toolkit簡化Redux
一、安裝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)出一個空的Redux store開始。
store/index.js // 使用rtk來創(chuàng)建store import { configureStore } from '@reduxjs/toolkit' import useReducer from './userSlice' /* 使用rtk的時候,reducer依然可以使用之前的創(chuàng)建不變 但是不再需要去合并reducer combineReducers rtk提供了configureStore方法,直接接收一個對象作為參數(shù) 可以將reducer的相關(guān)配置直接通過這個對象進行傳遞,不再需單獨合并reducer reducer屬性可以直接單獨傳遞一個ruducer,也可以傳遞一個對象 */ 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作為一個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)建一個Redux State Slice
slice需要一個name作為唯一標識,需要有初始化state值,還需要至少一個reducer方法來定義state如何變化。一旦slice創(chuàng)建完成我們就可以導(dǎo)出生成的Redux action creators和整個slice的reducer方法。
Redux需要我們通過制作數(shù)據(jù)副本和更新副本來不可變地更新state。然而Redux Toolkit的createSlice 和 createReducer API內(nèi)部使用了Immer,這允許我們可以直接寫更新邏輯,不必制作副本,它將自動成為正確的不可變更新。
userSlice.js文件
// 切片對象 import { createSlice } from '@reduxjs/toolkit' /* reducer切片 createSlice函數(shù)的作用:生成分片的reducer 內(nèi)部調(diào)用的市createAction和createReducer creatSlice可以幫助我們用更少的代碼去生成配套的reducer和action,而且有很好的維護性 */ const userSlice = createSlice({ name: 'zhangsan', // 標識符,生成actions的時候要使用, // state初始值 initialState: { name: '張三', age: 18, gender: '男' } , // reducer的具體方法, reducers: { // 指定state的各種操作,直接就可以在對象中添加方法 setName(state, action) { /* 可以通過不同的方法修來指定對state的不同的操作 state,action 可以直接修改state => state 是一個代理對象 之前的復(fù)制一份,返回一個新的對象 */ state.name = action.payload }, setAge(state, action) { state.age = action.payload } } }) /* 切片對象會自動地幫助我們生成action 切片對象會根據(jù)我們地reducers方法來自動地創(chuàng)建action對象,這些action對象會保存到切片對象的actions中 {type:name/函數(shù)名,payload:函數(shù)的參數(shù)} */ // 實際開發(fā)中,setName,setAge對外暴露, 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來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é):
1、使用configureStore創(chuàng)建一個Redux Store
- configureStore接收reducer方法作為命名參數(shù),或者說作為reducer對象的屬性
- configureStore會使用默認設(shè)置自動設(shè)置好store
2、在React組件中使用 Redux store
- 用React-Redux提供的 包裹你的
- 使用 傳入Redux store
3、使用createSlice創(chuàng)建Redux “slice” reducer
- createSlice需要有name屬性作為唯一標識,還需要初始化state和已命名的reducer方法
- Reducer方法通過使用Immer可以直接“改變”state,而不必手動做副本
- 導(dǎo)出生成的slice reducer 和 action creators
4、在React組件中使用React-Redux的useSelector/useDispatch鉤子
- 使用useSelector鉤子從store中讀數(shù)據(jù)
- 使用useDispatch鉤子獲取到dispatch方法,并且根據(jù)需要dispatch actions
到此這篇關(guān)于如何使用Redux Toolkit簡化Redux的文章就介紹到這了,更多相關(guān)Redux Toolkit內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
antd中form表單的wrapperCol和labelCol問題詳解
最近學(xué)習(xí)中遇到了些問題,所以給大家總結(jié),下面這篇文章主要給大家介紹了關(guān)于antd中form表單的wrapperCol和labelCol問題的相關(guān)資料,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下2023-02-02React模仿網(wǎng)易云音樂實現(xiàn)一個音樂項目詳解流程
這篇文章主要介紹了React模仿網(wǎng)易云音樂實現(xiàn)一個音樂項目的詳細流程,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2022-08-08react同構(gòu)實踐之實現(xiàn)自己的同構(gòu)模板
這篇文章主要介紹了react同構(gòu)實踐之實現(xiàn)自己的同構(gòu)模板,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-03-03