亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

React?Flux與Redux設(shè)計(jì)及使用原理

 更新時(shí)間:2023年03月16日 10:01:41   作者:糖^O^  
這篇文章主要介紹了React?Flux與Redux設(shè)計(jì)及使用,Redux最主要是用作應(yīng)用狀態(tài)的管理。簡(jiǎn)言之,Redux用一個(gè)單獨(dú)的常量狀態(tài)樹(state對(duì)象)保存這一整個(gè)應(yīng)用的狀態(tài),這個(gè)對(duì)象不能直接被改變

Flux 是一種架構(gòu)思想,專門解決軟件的結(jié)構(gòu)問題。它跟MVC架構(gòu)是同一類東西,但是更加簡(jiǎn)單和清晰。Flux存在多種實(shí)現(xiàn)(至少15種)

Facebook Flux是用來構(gòu)建客戶端Web應(yīng)用的應(yīng)用架構(gòu)。它利用單向數(shù)據(jù)流的方式來組合React

中的視圖組件。它更像一個(gè)模式而不是一個(gè)正式的框架,開發(fā)者不需要太多的新代碼就可以快速的上手Flux。

Facebook Flux是用來構(gòu)建客戶端Web應(yīng)用的應(yīng)用架構(gòu)。它利用單向數(shù)據(jù)流的方式來組合React

中的視圖組件。它更像一個(gè)模式而不是一個(gè)正式的框架,開發(fā)者不需要太多的新代碼就可以快速的上手Flux。

Redux最主要是用作應(yīng)用狀態(tài)的管理。簡(jiǎn)言之,Redux用一個(gè)單獨(dú)的常量狀態(tài)樹(state對(duì)象)保存這一整個(gè)應(yīng)用的狀態(tài),這個(gè)對(duì)象不能直接被改變。當(dāng)一些數(shù)據(jù)變化了,一個(gè)新的對(duì)象就會(huì)被創(chuàng)建(使用actions和reducers),這樣就可以進(jìn)行數(shù)據(jù)追蹤,實(shí)現(xiàn)時(shí)光旅行。

1. redux介紹及設(shè)計(jì)和使用的三大原則

單一數(shù)據(jù)源

整個(gè)應(yīng)用的state被儲(chǔ)存在一棵object tree中,并且這個(gè)object tree只存在于唯一 一個(gè)store中

State是只讀的

唯一改變state的方法就是觸發(fā)action,action是一個(gè)用于描述已發(fā)生事件的普通對(duì)象.

使用純函數(shù)來執(zhí)行修改

描述action如何改變staet tree,需要編寫reducers.

2. redux工作流

Redux工作流程:

  • View在redux中會(huì)派發(fā)action方法 action通過store的dispatch方法會(huì)派發(fā)給store
  • store接收action,連同之前的state,一起傳遞給reducer reducer返回新的數(shù)據(jù)給store
  • store去改變自己的state

3. redux原理解析

store 是通過 createStore創(chuàng)建出來的,
所以他的結(jié)構(gòu)
export const createStore =
function(reducer, initialState) {
return {
dispatch, 用于action的分發(fā),
改變store里面的state(currentState =
reducer(currentState,action)) ,并
在內(nèi)部遍歷subcribe注冊(cè)的監(jiān)聽器
subscribe,注冊(cè)listener,
store里面state發(fā)生改變后,執(zhí)行該
listener
getState, 取store里面的
state
}
}
function createStore(reducer){
var list = [];
var state =reducer();
function subscribe(callback){
list.push(callback);
}
function dispatch(data){
state =
reducer(state,data);
for(var i in list){
list[i]();
}
}
function getState(){
return state;
}
return {
subscribe,
dispatch,
getState
}
}

4. reducer 擴(kuò)展

如果不同的action所處理的屬性之間沒有聯(lián)系,我們可以把 Reducer 函數(shù)拆分。

不同的函數(shù)負(fù)責(zé)處理不同屬性,最終把它們合并成一個(gè)大的 Reducer 即可

import {combineReducers} from "redux";
const reducer = combineReducers({
a: functionA,
b: functionB,
c: functionC
})
訪問:
(state)=>{
return {
kerwinstate:state.a (不同的命名空間)
}
}

5. redux中間件

在redux里,action僅僅是攜帶了數(shù)據(jù)的普通js對(duì)象,action creator返回的值是這個(gè)action類型的對(duì)象。

然后通過store.dispatch()進(jìn)行分發(fā)。同步的情況下一切都很完美,但reducer無法處理異步的情況,那么我們就需要在action和reducer中間架起一座橋梁來處理異步

i. 中間件的由來與原理、機(jī)制

export default function thunkMiddleware({ dispatch, getState }) {
return next => action =>
typeof action === 'function' ?
action(dispatch, getState) :
next(action);
}

這段代碼的意思是,中間件這個(gè)橋梁接受到的參數(shù)action,如果不是function則和過去一樣直接執(zhí)

行next方法(下一步處理),相當(dāng)于中間件沒有做任何事。如果action是function,則先執(zhí)行action,

action的處理結(jié)束之后,再在action的內(nèi)部調(diào)用dispatch。

ii. 常用異步中間件:

redux-thunk (store.dispatch參數(shù)可以是一個(gè)function)

import thunk from 'redux-thunk';
import {applyMiddleware} from "redux";
const store = createStore(fetchReducer, applyMiddleware(thunk));
const getComingSoon = ()=>{
//進(jìn)行異步請(qǐng)求
return (dispatch,store)=>{
}
}

redux-promise (store.dispatch參數(shù)可以是一個(gè)promise對(duì)象)

import promiseMiddleware from 'redux-promise';
const store = createStore(fetchReducer, applyMiddleware(thunk,promiseMiddleware));
const getComingSoon = ()=>{
//進(jìn)行異步請(qǐng)求
return axios.get(`****`).then(res=>{
return {
type:"cominglist",
info:res.data.data
}
})
}

6. Redux DevTools Extension

redux-devtools-extension 的使用

插件安裝

$ npm install redux-devtools-extension -D

下載完成之后

  • 可以在瀏覽器工具欄右上角可以看到圖標(biāo)(當(dāng)應(yīng)用可以使用該工具時(shí),圖標(biāo)變亮)
  • 在頁面上右鍵可以看到 Redux DevTools 選項(xiàng)
  • 打開控制臺(tái),在菜單欄可以找到 Redux 菜單欄
import { createStore, compose} from 'redux'
import reducer from './reducer'
const composeEnhancers = window.__REDUX_DEVTOOLS_EXTENSION_COMPOSE__ || compose;
const store = createStore(reducer, /* preloadedState, */ composeEnhancers())
export default store

到此這篇關(guān)于React Flux與Redux設(shè)計(jì)及使用原理的文章就介紹到這了,更多相關(guān)React Flux與Redux內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • React使用Echarts/Ant-design-charts的案例代碼

    React使用Echarts/Ant-design-charts的案例代碼

    這篇文章主要介紹了React使用Echarts/Ant-design-charts的實(shí)例代碼,本文通過實(shí)例代碼給大家講解的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-11-11
  • React中的useEffect useLayoutEffect到底怎么用

    React中的useEffect useLayoutEffect到底怎么用

    這篇文章主要介紹了React中的useEffect useLayoutEffect具體使用方法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)吧
    2023-02-02
  • react如何修改循環(huán)數(shù)組對(duì)象的數(shù)據(jù)

    react如何修改循環(huán)數(shù)組對(duì)象的數(shù)據(jù)

    這篇文章主要介紹了react如何修改循環(huán)數(shù)組對(duì)象的數(shù)據(jù)問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-12-12
  • react map使用方法實(shí)例詳解

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

    map()方法是在React中常用的數(shù)組處理方法之一,可以用于遍歷數(shù)組、生成組件列表以及進(jìn)行數(shù)據(jù)轉(zhuǎn)換等操作,通過合理運(yùn)用map()方法,可以更靈活地處理和展示數(shù)據(jù),下面給大家講解react map使用方法,感興趣的朋友一起看看吧
    2023-10-10
  • 如何在React?Native開發(fā)中防止滑動(dòng)過程中的誤觸

    如何在React?Native開發(fā)中防止滑動(dòng)過程中的誤觸

    在使用React?Native開發(fā)的時(shí),當(dāng)我們快速滑動(dòng)應(yīng)用的時(shí)候,可能會(huì)出現(xiàn)誤觸,導(dǎo)致我們會(huì)點(diǎn)擊到頁面中的某一些點(diǎn)擊事件,誤觸導(dǎo)致頁面元素響應(yīng)從而進(jìn)行其他操作,表現(xiàn)出非常不好的用戶體驗(yàn)。
    2023-05-05
  • 如何將你的AngularJS1.x應(yīng)用遷移至React的方法

    如何將你的AngularJS1.x應(yīng)用遷移至React的方法

    本篇文章主要介紹了如何將你的AngularJS1.x應(yīng)用遷移至React的方法,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-02-02
  • React中styled-components的使用

    React中styled-components的使用

    styled-components 樣式化組件,主要作用是它可以編寫實(shí)際的CSS代碼來設(shè)計(jì)組件樣式,本文主要介紹了React中styled-components的使用,具有一定的參考價(jià)值,感興趣的可以了解一下
    2022-04-04
  • react中的雙向綁定你真的了解嗎

    react中的雙向綁定你真的了解嗎

    這篇文章主要為大家詳細(xì)介紹了react中的雙向綁定,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2022-03-03
  • react實(shí)現(xiàn)導(dǎo)航欄二級(jí)聯(lián)動(dòng)

    react實(shí)現(xiàn)導(dǎo)航欄二級(jí)聯(lián)動(dòng)

    這篇文章主要為大家詳細(xì)介紹了react實(shí)現(xiàn)導(dǎo)航欄二級(jí)聯(lián)動(dòng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-03-03
  • React?Fiber?鏈表操作及原理示例詳解

    React?Fiber?鏈表操作及原理示例詳解

    這篇文章主要為大家介紹了React?Fiber?鏈表操作原理詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-10-10

最新評(píng)論