react-redux及redux狀態(tài)管理工具使用詳解
react-redux使用及原理
1、下載 react-redux redux redux-thunk三個(gè)依賴包
yarn add react-redux redux redux-thunk
2、配置store對(duì)象,用來(lái)管理全局狀態(tài)
import { createStore, combineReducers, applyMiddleware } from "redux" // redux-thunk中間件,用來(lái)處理異步傳值的方法 import reduxThunk from "redux-thunk" import Reducer1 from "./reducer/Reducer1" import Reducer2 from "./reducer/Reducer2" import Reducer3 from "./reducer/Reducer3" // combineReducers方法用來(lái)合并reducer,將reducer分開(kāi),便于管理 const reducer = combineReducers({ Reducer1, Reducer2, Reducer3, }) // 創(chuàng)建store對(duì)象,并將其暴露出去 const store = createStore( reducer, applyMiddleware(reduxThunk) ) export default store
3、創(chuàng)建reducer.js文件, reducer文件主要是用來(lái)處理改變store狀態(tài)里面的值
const reducer1 = (prevState = { num: 10 }, action) => { let newState = { ...prevState } switch(action.type) { case "TYPE1": newState.num = action.value return newState default: return prevState } } export default reducer1
4、在入口文件index.js中引入provider,并包裹在App根組件外,其中的store就是創(chuàng)建的store對(duì)象
import React from 'react'; import ReactDOM from 'react-dom/client'; import { Provider } from "react-redux" import App from './studyReactRedux/App'; import "./static/main.css" import store from "./studyReactRedux/reactRedux/index"; const root = ReactDOM.createRoot(document.getElementById('root')); root.render( <Provider store = { store }> <App></App> </Provider> )
至此在react所有的組件中都有了store對(duì)象,方便存取全局狀態(tài)了
接下來(lái)就是在組件中存值取值了
1、在組件中取值
<div> {props.num} </div> const matStateToProps = (state) => { return { num: state.Reducer1.num } } export default connect(matStateToProps, mapDispatchToProps)(Home)
2、組件中存值(同步)
const handleClick = (val) => { props.changeVal(val) } <button onClick={ () => handleClick('同步傳過(guò)去的值') }>同步存值</button> const mapDispatchToProps = { changeVal(val) { return { type: 'TYPE1', value: val } } } export default connect(matStateToProps, mapDispatchToProps)(Home)
3、組件中存值(異步)
const handleClick = (val) => { props.changeVal(val) } <button onClick={ () => handleClick('同步傳過(guò)去的值') }>同步存值</button> const mapDispatchToProps = { changeVal(val) { return (dispatch) => { setTimeout(()=> { dispatch({ type: 'TYPE1', value: val }) }, 300) } } } export default connect(matStateToProps, mapDispatchToProps)(Home)
react-redux持久化
// 持久化可以自己在存狀態(tài)的時(shí)候自己往local session里面存值,借助redux-persist庫(kù) // 1、下載redux-persist yarn add redux-persist // 2、修改 store文件 /** * * react-redux的使用步驟 * * 1、引入react-redux 和 redux 和 redux-thunk * * 2、index.js中引入 import { Provider } from "react-redux" * * 3、在根組件中App外面包上一層 <Provider store={ store }></Provider>, 其中store就是redux中創(chuàng)建的store對(duì)象 * * 4、在組件中使用connect( (state)=>{ * return { state: state.xxxReducer.xxx } * } )(App) * 其中的 connect 是從 react-redux 中解構(gòu)出來(lái)的 import { connect } from "react-redux" * connect函數(shù)中有兩個(gè)參數(shù): 第一個(gè)是從store狀態(tài)中取值的,第二個(gè)是dispatch傳值的 * * 詳細(xì)見(jiàn)home中的child1給child2傳值, child2給child1傳值 */ import { createStore, combineReducers, applyMiddleware } from "redux" import reduxThunk from "redux-thunk" import {persistStore, persistReducer} from 'redux-persist' import storage from 'redux-persist/lib/storage' import Reducer1 from "./reducer/Reducer1" import Reducer2 from "./reducer/Reducer2" import Reducer3 from "./reducer/Reducer3" const persistConfig = { key: 'item', storage, whitelist: ['Reducer1'] // 表示只持久化 Reducer1的值 blacklist: ['Reducer2'] 表示不持久化Reducer2 } const reducer = combineReducers({ Reducer1, Reducer2, Reducer3, }) const myPersistReducer = persistReducer(persistConfig, reducer) const store = createStore(myPersistReducer, applyMiddleware(reduxThunk)) const persistor = persistStore(store) export { store, persistor } // 3、修改入口文件 index.js import React from 'react'; import ReactDOM from 'react-dom/client'; import { Provider } from "react-redux" import App from './studyReactRedux/App'; import "./static/main.css" import { store, persistor } from "./studyReactRedux/reactRedux/index"; import {PersistGate} from 'redux-persist/integration/react' import { HashRouter } from "react-router-dom" const root = ReactDOM.createRoot(document.getElementById('root')); root.render( <Provider store = { store }> <PersistGate loading={null} persistor={persistor}> <HashRouter> <App></App> </HashRouter> </PersistGate> </Provider> )
不管是同步改狀態(tài)還是異步改狀態(tài),只要dispatch就會(huì)發(fā)布action動(dòng)作到store對(duì)象中,store交給reducer來(lái)處理修改響應(yīng)的狀態(tài),從而達(dá)到了解耦的效果
redux的使用詳解
redux是原生js實(shí)現(xiàn)的,和react沒(méi)有直接的關(guān)系,使用起來(lái)相對(duì)react-redux稍微麻煩點(diǎn),需要使用人員自己動(dòng)手進(jìn)行消息訂閱和取消訂閱
配置store對(duì)象和react-redux一樣,見(jiàn)上面配置文件,只是不需要在App根組件中注入provider供應(yīng)商
在使用的過(guò)程中不太一樣,沒(méi)有connect高階組件
1、組件中取值
// 其中的store就是引入的store對(duì)象 const [val, setVal] = useState(store.getState().Reducer1.num) // 取store中的初始值 useEffect(()=>{ // 訂閱消息,當(dāng)store中的值發(fā)生改變的時(shí)候就會(huì)走到此方法里面來(lái) const unsubscibe = store.subscribe(() => { setVal(store.getState().Reducer1.num) }) return() => { // 取消訂閱 unsubscibe() } }, []) <div>{val}</div>
2、組件中存值(同步)
handleClick(val) { store.dispatch({ type: 'TYPE1', value: val }) }
3、組件中存值(異步)
handleClick(val) { store.dispatch((dispatch) => { dispatch({ type: 'TYPE1', value: val }) }) }
到此這篇關(guān)于react-redux以及redux狀態(tài)管理工具詳解的文章就介紹到這了,更多相關(guān)react-redux狀態(tài)管理內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
記一次react前端項(xiàng)目打包優(yōu)化的方法
這篇文章主要介紹了記一次react前端項(xiàng)目打包優(yōu)化的方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-03-03react中使用redux-persist做持久化儲(chǔ)存的過(guò)程記錄
這篇文章主要介紹了react中使用redux-persist做持久化儲(chǔ)存的相關(guān)資料,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2024-01-01React Antd中如何設(shè)置表單只輸入數(shù)字
這篇文章主要介紹了React Antd中如何設(shè)置表單只輸入數(shù)字問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-06-06React過(guò)渡動(dòng)畫(huà)組件基礎(chǔ)使用介紹
在開(kāi)發(fā)中,我們想要給一個(gè)組件的顯示和消失添加某種過(guò)渡動(dòng)畫(huà),可以很好的增加用戶體驗(yàn)。 當(dāng)然,我們可以通過(guò)原生的CSS來(lái)實(shí)現(xiàn)這些過(guò)渡動(dòng)畫(huà),這篇文章主要介紹了React過(guò)渡動(dòng)畫(huà)組件使用2022-09-09React組件三大核心屬性State?props?Refs介紹
組件實(shí)例的三大核心屬性是:State、Props、Refs。類組件中這三大屬性都存在。函數(shù)式組件中訪問(wèn)不到?this,也就不存在組件實(shí)例這種說(shuō)法,但由于它的特殊性(函數(shù)可以接收參數(shù)),所以存在Props這種屬性2023-02-02