欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

react-redux及redux狀態(tài)管理工具使用詳解

 更新時(shí)間:2023年01月31日 12:00:15   作者:weixin_43993776  
Redux是為javascript應(yīng)用程序提供一個(gè)狀態(tài)管理工具集中的管理react中多個(gè)組件的狀態(tài)redux是專門(mén)作狀態(tài)管理的js庫(kù)(不是react插件庫(kù)可以用在其他js框架中例如vue,但是基本用在react中),這篇文章主要介紹了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)化的方法

    這篇文章主要介紹了記一次react前端項(xiàng)目打包優(yōu)化的方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-03-03
  • React?Hook之使用State?Hook的方法

    React?Hook之使用State?Hook的方法

    這篇文章主要為大家詳細(xì)介紹了React使用State?Hook的方法,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來(lái)幫助
    2022-03-03
  • react中使用redux-persist做持久化儲(chǔ)存的過(guò)程記錄

    react中使用redux-persist做持久化儲(chǔ)存的過(guò)程記錄

    這篇文章主要介紹了react中使用redux-persist做持久化儲(chǔ)存的相關(guān)資料,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2024-01-01
  • react-router-dom之異步加載路由方式

    react-router-dom之異步加載路由方式

    這篇文章主要介紹了react-router-dom之異步加載路由方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-03-03
  • React Antd中如何設(shè)置表單只輸入數(shù)字

    React Antd中如何設(shè)置表單只輸入數(shù)字

    這篇文章主要介紹了React Antd中如何設(shè)置表單只輸入數(shù)字問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-06-06
  • React過(guò)渡動(dòng)畫(huà)組件基礎(chǔ)使用介紹

    React過(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-09
  • react map使用方法實(shí)例詳解

    react map使用方法實(shí)例詳解

    map()方法是在React中常用的數(shù)組處理方法之一,可以用于遍歷數(shù)組、生成組件列表以及進(jìn)行數(shù)據(jù)轉(zhuǎn)換等操作,通過(guò)合理運(yùn)用map()方法,可以更靈活地處理和展示數(shù)據(jù),下面給大家講解react map使用方法,感興趣的朋友一起看看吧
    2023-10-10
  • React組件三大核心屬性State?props?Refs介紹

    React組件三大核心屬性State?props?Refs介紹

    組件實(shí)例的三大核心屬性是:State、Props、Refs。類組件中這三大屬性都存在。函數(shù)式組件中訪問(wèn)不到?this,也就不存在組件實(shí)例這種說(shuō)法,但由于它的特殊性(函數(shù)可以接收參數(shù)),所以存在Props這種屬性
    2023-02-02
  • 深入淺析react native es6語(yǔ)法

    深入淺析react native es6語(yǔ)法

    這篇文章主要介紹了深入淺析react native es6語(yǔ)法的相關(guān)資料,需要的朋友可以參考下
    2015-12-12
  • webpack3+React 的配置全解

    webpack3+React 的配置全解

    本篇文章主要介紹了webpack3+React 的配置全解,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2017-08-08

最新評(píng)論