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

react dva實(shí)現(xiàn)的代碼

 更新時(shí)間:2021年11月08日 11:11:02   作者:lin-fighting  
dva是一個(gè)基于redux和redux-saga的數(shù)據(jù)流方案,然后為了簡(jiǎn)化開(kāi)發(fā)體驗(yàn),dva額外內(nèi)置了react-router,fetch,可以激烈為一個(gè)輕量級(jí)的應(yīng)用框架,這篇文章主要介紹了react dva實(shí)現(xiàn),需要的朋友可以參考下

dva

dva是一個(gè)基于redux和redux-saga的數(shù)據(jù)流方案,然后為了簡(jiǎn)化開(kāi)發(fā)體驗(yàn),dva額外內(nèi)置了react-router,fetch,可以激烈為一個(gè)輕量級(jí)的應(yīng)用框架。

在這里插入圖片描述

使用dva

在這里插入圖片描述

定義一個(gè)模型,有點(diǎn)像redux-toolkit。
使用connect連接

在這里插入圖片描述
在這里插入圖片描述

像redux的connect一樣連接。

在這里插入圖片描述

啟動(dòng)。
然后如何派發(fā)action。

在這里插入圖片描述

通過(guò)對(duì)應(yīng)的指令找到對(duì)印的reducer,派發(fā)。

在這里插入圖片描述

dva的基本操作就是這樣,使用起來(lái)比較輕便。

實(shí)現(xiàn)dva

思路:封裝一個(gè)函數(shù),創(chuàng)建store,通過(guò)model收集reducer和state,改變r(jià)educer中的方法名字。

在這里插入圖片描述

首先是model。因?yàn)橛卸鄠€(gè)model,所以我們要收集起來(lái)。

在這里插入圖片描述

先通過(guò)namesapce改變r(jià)ducer中的方法名字。

在這里插入圖片描述

再將其保存起來(lái)。

在這里插入圖片描述
在這里插入圖片描述

然后通過(guò)Provider就可以注入進(jìn)去。

在這里插入圖片描述

改造model的reducer,返回redux接受的reducer。此時(shí)model的state是不會(huì)變的,他只是初始的state,組件真正接受的是redux中的state。
這個(gè)getReducer只會(huì)調(diào)用一次,用來(lái)返回真正的reducer。

在這里插入圖片描述

初步實(shí)現(xiàn)完畢。

支持異步

dva是集成redux-saga的,所以用法也類(lèi)似。

在這里插入圖片描述

在創(chuàng)建model的時(shí)候可以通過(guò)effects創(chuàng)建saga中間件。然后派發(fā)對(duì)應(yīng)的action

在這里插入圖片描述
在這里插入圖片描述

實(shí)現(xiàn)

思路:處理每個(gè)model的effects,轉(zhuǎn)會(huì)為對(duì)應(yīng)的saga函數(shù),采用takeEvery監(jiān)聽(tīng)每個(gè)屬性名(如asyncADD,轉(zhuǎn)化為takeEvery(‘a(chǎn)syncADD', ()=>{})等等),然后通過(guò)redux-saga提供的createSagaMiddleware創(chuàng)建一個(gè)中間件,利用run方法執(zhí)行各個(gè)model中的effects轉(zhuǎn)化后的saga函數(shù)。
代碼:

在這里插入圖片描述

通過(guò)getSagas轉(zhuǎn)化每個(gè)model的effects并且存在一個(gè)數(shù)組里面,然后通過(guò)forEach一個(gè)個(gè)run起來(lái)。
看如何轉(zhuǎn)化

在這里插入圖片描述

可以看到,每個(gè)model的effects會(huì)在getSaga被轉(zhuǎn)化為function*(){},然后遍歷單個(gè)model的effects,對(duì)每個(gè)屬性都做比如*asyncADD(){}處理,如圖通過(guò)getWatcher返回個(gè)saga函數(shù),通過(guò)fork開(kāi)啟一個(gè)子進(jìn)程,不會(huì)干擾主進(jìn)程的運(yùn)行。

在這里插入圖片描述

而每個(gè)getWatcher返回的就是saga函數(shù)(generator函數(shù))他會(huì)通過(guò)takeEvery監(jiān)聽(tīng)當(dāng)前的屬性(key)并且執(zhí)行后面那個(gè)effects。這里需要改造一下redux-saga的Put方法,使他單獨(dú)做一些prefixType的邏輯。
這樣就基本完成,每個(gè)model的effects都會(huì)被處理城saga函數(shù)去run,而且effects的每個(gè)方法都轉(zhuǎn)化為了key,通過(guò)takeEvery去監(jiān)聽(tīng)。這里還需要對(duì)effect的每個(gè)方法名加上前綴

在這里插入圖片描述

這樣就大功搞成了。

在這里插入圖片描述

可以正常運(yùn)行。

router的實(shí)現(xiàn)

在這里插入圖片描述
在這里插入圖片描述

使用沒(méi)什么區(qū)別
dva是繼承了connected-react-router的

在這里插入圖片描述
在這里插入圖片描述

所以用法跟其差不多,注意,異步的邏輯只能寫(xiě)在effects,reducer是同步的,不能繼續(xù)派發(fā)的。

在這里插入圖片描述
在這里插入圖片描述
在這里插入圖片描述

實(shí)現(xiàn):

在這里插入圖片描述
在這里插入圖片描述
在這里插入圖片描述

基于connectd-react-router

在這里插入圖片描述

還記得connectd-react-router怎么使用嗎,第一步,創(chuàng)建router對(duì)象。

在這里插入圖片描述

第二步,使用中間件。

在這里插入圖片描述

傳入api給app._router作為參數(shù)。這樣就完成了。

在這里插入圖片描述

當(dāng)他派發(fā)push的時(shí)候會(huì)被路由中間件攔截處理,push到另一個(gè)頁(yè)面去。

到此這篇關(guān)于react dva實(shí)現(xiàn)的文章就介紹到這了,更多相關(guān)react dva實(shí)現(xiàn)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • React native ListView 增加頂部下拉刷新和底下點(diǎn)擊刷新示例

    React native ListView 增加頂部下拉刷新和底下點(diǎn)擊刷新示例

    這篇文章主要介紹了React native ListView 增加頂部下拉刷新和底下點(diǎn)擊刷新示例,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2018-04-04
  • react-router-dom?降低版本的兩種方法詳解

    react-router-dom?降低版本的兩種方法詳解

    這篇文章主要介紹了react-router-dom?降低版本的兩種方法,本篇文章就記錄下如何降低 react-router-dom 為 v5 版本的兩種方法,需要的朋友可以參考下
    2022-12-12
  • 詳解如何在React中優(yōu)雅的使用addEventListener

    詳解如何在React中優(yōu)雅的使用addEventListener

    這篇文章主要為大家詳細(xì)介紹了如何在React中優(yōu)雅的使用addEventListener,文中的示例代碼簡(jiǎn)潔易懂,對(duì)大家學(xué)習(xí)React有一定的幫助,需要的可以參考一下
    2023-01-01
  • React父組件調(diào)用子組件中的方法實(shí)例詳解

    React父組件調(diào)用子組件中的方法實(shí)例詳解

    最近做一個(gè)React項(xiàng)目,所有組件都使用了函數(shù)式組件,遇到一個(gè)父組件調(diào)用子組件方法的問(wèn)題,下面這篇文章主要給大家介紹了關(guān)于React父組件調(diào)用子組件中方法的相關(guān)資料,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2022-07-07
  • 深入分析React源碼中的合成事件

    深入分析React源碼中的合成事件

    合成事件不是瀏覽器本身觸發(fā)的事件,自己創(chuàng)建和觸發(fā)的事件。本文將從源碼角度帶大家一起深入了解下React中的合成事件,需要的可以參考一下
    2022-11-11
  • react中將html字符串渲染到頁(yè)面的實(shí)現(xiàn)方式

    react中將html字符串渲染到頁(yè)面的實(shí)現(xiàn)方式

    這篇文章主要介紹了react中將html字符串渲染到頁(yè)面的實(shí)現(xiàn)方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-12-12
  • React-redux?中useSelector使用源碼分析

    React-redux?中useSelector使用源碼分析

    在一個(gè) action 被分發(fā)(dispatch) 后,useSelector() 默認(rèn)對(duì) select 函數(shù)的返回值進(jìn)行引用比較 ===,并且僅在返回值改變時(shí)觸發(fā)重渲染,,這篇文章主要介紹了React-redux?中useSelector使用,需要的朋友可以參考下
    2023-10-10
  • React跨路由組件動(dòng)畫(huà)實(shí)現(xiàn)

    React跨路由組件動(dòng)畫(huà)實(shí)現(xiàn)

    在 React 中路由之前的切換動(dòng)畫(huà)可以使用 react-transition-group 來(lái)實(shí)現(xiàn),但對(duì)于不同路由上的組件如何做到動(dòng)畫(huà)過(guò)渡是個(gè)很大的難題,目前社區(qū)中也沒(méi)有一個(gè)成熟的方案,本文給大家分享React跨路由組件動(dòng)畫(huà)實(shí)現(xiàn),感興趣的朋友一起看看吧
    2023-10-10
  • 詳解如何在React組件“外”使用父組件的Props

    詳解如何在React組件“外”使用父組件的Props

    這篇文章主要介紹了詳解如何在React組件“外”使用父組件的Props,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2018-01-01
  • react同構(gòu)實(shí)踐之實(shí)現(xiàn)自己的同構(gòu)模板

    react同構(gòu)實(shí)踐之實(shí)現(xiàn)自己的同構(gòu)模板

    這篇文章主要介紹了react同構(gòu)實(shí)踐之實(shí)現(xiàn)自己的同構(gòu)模板,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-03-03

最新評(píng)論