一文理解Redux及其工作原理
一、是什么
React是用于構(gòu)建用戶界面的,幫助我們解決渲染DOM的過程
而在整個(gè)應(yīng)用中會(huì)存在很多個(gè)組件,每個(gè)組件的state是由自身進(jìn)行管理,包括組件定義自身的state、組件之間的通信通過props傳遞、使用Context實(shí)現(xiàn)數(shù)據(jù)共享
如果讓每個(gè)組件都存儲(chǔ)自身相關(guān)的狀態(tài),理論上來講不會(huì)影響應(yīng)用的運(yùn)行,但在開發(fā)及后續(xù)維護(hù)階段,我們將花費(fèi)大量精力去查詢狀態(tài)的變化過程
這種情況下,如果將所有的狀態(tài)進(jìn)行集中管理,當(dāng)需要更新狀態(tài)的時(shí)候,僅需要對這個(gè)管理集中處理,而不用去關(guān)心狀態(tài)是如何分發(fā)到每一個(gè)組件內(nèi)部的
redux就是一個(gè)實(shí)現(xiàn)上述集中管理的容器,遵循三大基本原則:
- 單一數(shù)據(jù)源
- state 是只讀的
- 使用純函數(shù)來執(zhí)行修改
注意的是,redux并不是只應(yīng)用在react中,還與其他界面庫一起使用,如Vue
二、工作原理
redux要求我們把數(shù)據(jù)都放在 store公共存儲(chǔ)空間
一個(gè)組件改變了 store 里的數(shù)據(jù)內(nèi)容,其他組件就能感知到 store的變化,再來取數(shù)據(jù),從而間接的實(shí)現(xiàn)了這些數(shù)據(jù)傳遞的功能
工作流程圖如下所示:

根據(jù)流程圖,可以想象,React Components 是借書的用戶, Action Creactor 是借書時(shí)說的話(借什么書), Store 是圖書館管理員,Reducer 是記錄本(借什么書,還什么書,在哪兒,需要查一下), state 是書籍信息
整個(gè)流程就是借書的用戶需要先存在,然后需要借書,需要一句話來描述借什么書,圖書館管理員聽到后需要查一下記錄本,了解圖書的位置,最后圖書館管理員會(huì)把這本書給到這個(gè)借書人
轉(zhuǎn)換為代碼是,React Components 需要獲取一些數(shù)據(jù), 然后它就告知 Store 需要獲取數(shù)據(jù),這就是就是 Action Creactor , Store 接收到之后去 Reducer 查一下, Reducer 會(huì)告訴 Store 應(yīng)該給這個(gè)組件什么數(shù)據(jù)
三、如何使用
創(chuàng)建一個(gè)store的公共數(shù)據(jù)區(qū)域
import { createStore } from 'redux' // 引入一個(gè)第三方的方法
const store = createStore() // 創(chuàng)建數(shù)據(jù)的公共存儲(chǔ)區(qū)域(管理員)還需要?jiǎng)?chuàng)建一個(gè)記錄本去輔助管理數(shù)據(jù),也就是reduecer,本質(zhì)就是一個(gè)函數(shù),接收兩個(gè)參數(shù)state,action,返回state
// 設(shè)置默認(rèn)值
const initialState = {
counter: 0
}
const reducer = (state = initialState, action) => {
}然后就可以將記錄本傳遞給store,兩者建立連接。
如下:
const store = createStore(reducer)
如果想要獲取store里面的數(shù)據(jù),則通過store.getState()來獲取當(dāng)前state
console.log(store.getState());
下面再看看如何更改store里面數(shù)據(jù),是通過dispatch來派發(fā)action,通常action中都會(huì)有type屬性,也可以攜帶其他的數(shù)據(jù)
store.dispatch({
type: "INCREMENT"
})
store.dispath({
type: "DECREMENT"
})
store.dispatch({
type: "ADD_NUMBER",
number: 5
})下面再來看看修改reducer中的處理邏輯:
const reducer = (state = initialState, action) => {
switch (action.type) {
case "INCREMENT":
return {...state, counter: state.counter + 1};
case "DECREMENT":
return {...state, counter: state.counter - 1};
case "ADD_NUMBER":
return {...state, counter: state.counter + action.number}
default:
return state;
}
}注意,reducer是一個(gè)純函數(shù),不需要直接修改state
這樣派發(fā)action之后,既可以通過store.subscribe監(jiān)聽store的變化,如下:
store.subscribe(() => {
console.log(store.getState());
})在React項(xiàng)目中,會(huì)搭配react-redux進(jìn)行使用
完整代碼如下:
const redux = require('redux');
const initialState = {
counter: 0
}
// 創(chuàng)建reducer
const reducer = (state = initialState, action) => {
switch (action.type) {
case "INCREMENT":
return {...state, counter: state.counter + 1};
case "DECREMENT":
return {...state, counter: state.counter - 1};
case "ADD_NUMBER":
return {...state, counter: state.counter + action.number}
default:
return state;
}
}
// 根據(jù)reducer創(chuàng)建store
const store = redux.createStore(reducer);
store.subscribe(() => {
console.log(store.getState());
})
// 修改store中的state
store.dispatch({
type: "INCREMENT"
})
// console.log(store.getState());
store.dispatch({
type: "DECREMENT"
})
// console.log(store.getState());
store.dispatch({
type: "ADD_NUMBER",
number: 5
})
// console.log(store.getState());小結(jié)
- createStore可以幫助創(chuàng)建 store
- store.dispatch 幫助派發(fā) action , action 會(huì)傳遞給 store
- store.getState 這個(gè)方法可以幫助獲取 store 里邊所有的數(shù)據(jù)內(nèi)容
- store.subscrible 方法訂閱 store 的改變,只要 store 發(fā)生改變, store.subscrible 這個(gè)函數(shù)接收的這個(gè)回調(diào)函數(shù)就會(huì)被執(zhí)行
到此這篇關(guān)于一文理解Redux及其工作原理的文章就介紹到這了,更多相關(guān) Redux 工作原理內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
淺談react.js中實(shí)現(xiàn)tab吸頂效果的問題
下面小編就為大家?guī)硪黄獪\談react.js中實(shí)現(xiàn)tab吸頂效果的問題。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-09-09
使用React hook實(shí)現(xiàn)remember me功能
相信大家在使用 React 寫頁面的時(shí)候都遇到過完成 Remember me 的需求吧!本文就將這個(gè)需求封裝在一個(gè) React hook 中以供后續(xù)的使用,覺得有用的同學(xué)可以收藏起來以備不時(shí)之需,感興趣的小伙伴跟著小編一起來看看吧2024-04-04
使用React封裝一個(gè)Tree樹形組件的實(shí)例代碼
這篇文章主要介紹了使用React封裝一個(gè)Tree樹形組件的實(shí)例,文中通過代碼示例講解的非常詳細(xì),對大家的學(xué)習(xí)或工作有一定的幫助,需要的朋友可以參考下2024-03-03
react中使用Modal.confirm數(shù)據(jù)不更新的問題完美解決方案
這篇文章主要介紹了react中使用Modal.confirm數(shù)據(jù)不更新的問題解決方案,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-09-09

