react-redux及redux狀態(tài)管理工具使用詳解
react-redux使用及原理
1、下載 react-redux redux redux-thunk三個(gè)依賴包
yarn add react-redux redux redux-thunk
2、配置store對(duì)象,用來管理全局狀態(tài)
import { createStore, combineReducers, applyMiddleware } from "redux"
// redux-thunk中間件,用來處理異步傳值的方法
import reduxThunk from "redux-thunk"
import Reducer1 from "./reducer/Reducer1"
import Reducer2 from "./reducer/Reducer2"
import Reducer3 from "./reducer/Reducer3"
// combineReducers方法用來合并reducer,將reducer分開,便于管理
const reducer = combineReducers({
Reducer1,
Reducer2,
Reducer3,
})
// 創(chuàng)建store對(duì)象,并將其暴露出去
const store = createStore( reducer, applyMiddleware(reduxThunk) )
export default store3、創(chuàng)建reducer.js文件, reducer文件主要是用來處理改變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 reducer14、在入口文件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)了
接下來就是在組件中存值取值了
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('同步傳過去的值') }>同步存值</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('同步傳過去的值') }>同步存值</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庫
// 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)出來的 import { connect } from "react-redux"
* connect函數(shù)中有兩個(gè)參數(shù): 第一個(gè)是從store狀態(tài)中取值的,第二個(gè)是dispatch傳值的
*
* 詳細(xì)見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來處理修改響應(yīng)的狀態(tài),從而達(dá)到了解耦的效果
redux的使用詳解
redux是原生js實(shí)現(xiàn)的,和react沒有直接的關(guān)系,使用起來相對(duì)react-redux稍微麻煩點(diǎn),需要使用人員自己動(dòng)手進(jìn)行消息訂閱和取消訂閱
配置store對(duì)象和react-redux一樣,見上面配置文件,只是不需要在App根組件中注入provider供應(yīng)商
在使用的過程中不太一樣,沒有connect高階組件
1、組件中取值
// 其中的store就是引入的store對(duì)象
const [val, setVal] = useState(store.getState().Reducer1.num) // 取store中的初始值
useEffect(()=>{
// 訂閱消息,當(dāng)store中的值發(fā)生改變的時(shí)候就會(huì)走到此方法里面來
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?Redux實(shí)現(xiàn)React組件之間的數(shù)據(jù)共享
在復(fù)雜的React應(yīng)用中,組件之間的數(shù)據(jù)共享是必不可少的,為了解決這個(gè)問題,可以使用React?Redux來管理應(yīng)用的狀態(tài),并實(shí)現(xiàn)組件之間的數(shù)據(jù)共享,在本文中,我們將介紹如何使用React?Redux實(shí)現(xiàn)Count和Person組件之間的數(shù)據(jù)共享,需要的朋友可以參考下2024-03-03
React Native基礎(chǔ)入門之調(diào)試React Native應(yīng)用的一小步
這篇文章主要給大家介紹了關(guān)于React Native基礎(chǔ)入門之調(diào)試React Native應(yīng)用的相關(guān)資料,文中通過圖文介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2018-07-07
在?React?中如何從狀態(tài)數(shù)組中刪除一個(gè)元素
這篇文章主要介紹了在?React?中從狀態(tài)數(shù)組中刪除一個(gè)元素,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-03-03
React實(shí)現(xiàn)二級(jí)聯(lián)動(dòng)效果(樓梯效果)
這篇文章主要為大家詳細(xì)介紹了React實(shí)現(xiàn)二級(jí)聯(lián)動(dòng)效果,樓梯效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-09-09
React通過useContext特性實(shí)現(xiàn)組件數(shù)據(jù)傳遞
本文主要介紹了React如何通過useContext特性實(shí)現(xiàn)組件數(shù)據(jù)傳遞,文中有相關(guān)的代碼示例供大家參考,對(duì)我們學(xué)習(xí)React有一定的幫助,需要的朋友可以參考下2023-06-06
詳解一個(gè)基于react+webpack的多頁面應(yīng)用配置
這篇文章主要介紹了詳解一個(gè)基于react+webpack的多頁面應(yīng)用配置,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2019-01-01

