国产精品电影_久久视频免费_欧美日韩国产激情_成年人视频免费在线播放_日本久久亚洲电影_久久都是精品_66av99_九色精品美女在线_蜜臀a∨国产成人精品_冲田杏梨av在线_欧美精品在线一区二区三区_麻豆mv在线看

2021年React的狀態管理之爭:Hooks、Redux 和 Recoil

移動開發 移動應用
在本文中,我們試圖介紹 2021 年最流行的 React 狀態管理工具,它們如何在 React 狀態管理中發揮重要作用,以及何時在項目中使用它們。

多年來,React.JS 的大規模增長催生了不同的狀態管理庫等。

在撰寫本文時,我們可以使用 React 中可用的狀態管理庫是巨大的。因此,知道為特定項目選擇哪個狀態管理庫以免被來自 React 社區的噪音和新聞所迷惑是促進應用程序開發的重要因素。

[[417554]]

一些開發人員通過使用 React Hooks 來應對挑戰;其他人將它們與 Redux 或新發布的 Recoil 等應用程序狀態管理庫相結合。

在本文中,我們將討論在典型的 React 應用程序中使用 Redux、Hooks 和 Recoil 進行狀態管理及其最佳用例。

我們還將嘗試回答以下問題:

在選擇狀態管理庫之前要考慮什么指標?

注意:本教程將對有興趣開發需要狀態管理庫的 React 應用程序的讀者有所幫助。

本文不是 React 狀態管理的介紹。它需要對 React、hook 和一些 Redux 有基本的了解;因此,如果您開始使用 React 和 React 中的狀態管理,請在開始本教程之前先了解這些基礎知識。

簡而言之,什么是狀態?

狀態管理只是一種實現跨組件通信和數據共享的方式。它創建了一個具體的數據結構來表示您可以讀寫的應用程序狀態。

從 React 16.8 開始,每個 React 組件,無論是函數式還是類,都可以有一個狀態。

在最簡單的定義中,State 是一個 JavaScript 對象,它表示可以根據用戶的結果操作更改的組件部分。您也可以說狀態只是組件的內存。

當用戶在典型的 React 應用程序中執行操作時,組件的狀態會發生變化。雖然這還不錯,但如果應用程序開始擴展,它很快就會成為一個問題;因此,這樣一個應用程序的復雜性使得跟蹤所有依賴項變得非常困難。

為了回答介紹問題,假設我們正在構建一個電子商務應用程序;在這樣的應用程序中,幾乎每個元素都可以是一個組件——購物車、按鈕、查看購物車會話、結帳、登錄欄等。在這個應用程序中,添加到購物車的單個用戶操作可以影響許多其他組件通過:

  • 改變購物車組件本身的狀態
  • 將購物車添加到用戶的購物車歷史記錄中
  • 結帳產品項目

這只是提到我們可以添加到電子商務應用程序的其他大量內容中的一些內容。如果負責工程師在開發應用程序時不考慮可擴展性,從長遠來看,他們很快就會遇到許多錯誤和問題。

像這樣不斷調試和改進應用程序最終可能會很痛苦。

上述場景向我們展示了狀態在典型 React 應用程序中的重要性。

在管理此應用程序中的狀態時,我們可以使用我們選擇的任何庫;無論如何,他們仍然會完成工作。

通常,狀態必須被提升到最近的父組件和下一個,直到它到達需要狀態的兩個組件的共同祖先,然后它被傳遞下來。這個過程可能是壓倒性的,并使狀態難以維持。通常,您可能需要將數據傳遞給甚至不需要它的組件。

隨著應用程序變大,狀態管理變得混亂。這就是為什么您需要像 Redux、Recoil 這樣的狀態管理工具,以便更輕松地維護這些狀態。

在接下來的部分中,我們將實際了解所有狀態管理庫(Redux、Hooks、Recoil)、它們的獨特性以及在使用它們之前需要考慮的事項。

Redux

我們列表中的第一個是 Redux;它已經存在了一段時間,幾乎是第一個基于 React 的狀態管理庫。

創建狀態管理庫 Redux 是為了解決我們電子商務應用程序中的問題。它提供了一個名為 store 的 JavaScript 對象,一旦設置,它就會包含應用程序中的所有狀態,并在必要時更新它們。這是 Redux 工作原理的簡化可視化。

也許你會問,為什么 Redux 經常與 React 一起使用?我的經驗是因為 Redux 會根據用戶的操作來處理狀態更新,尤其是在 UI 中;除此之外,Redux 可以用作任何框架的獨立狀態管理。

什么時候使用 Redux?

截至本文撰寫之時,Redux 是最流行的 React 狀態管理庫之一。

在本節中,我們將仔細研究何時在應用程序中使用 Redux。

首先,Redux 允許您在一個地方管理應用程序的狀態,并使應用程序中的更改更具可預測性和可追溯性。它使您的應用程序中發生的更改更容易弄清楚。不幸的是,所有這些好處都伴隨著特定的限制和權衡。

通常,開發人員覺得使用 Redux 會增加一些樣板代碼,使小事情看起來勢不可擋;然而,這完全取決于應用程序的架構決策。

了解何時真正需要使用 Redux 的最簡單方法之一是在本地管理狀態開始變得混亂時。

隨著應用程序的增長,跨組件的狀態共享也會變得乏味。

那時,您現在就開始尋找使流程輕松的方法。

在下一節中,我們將看看為什么我們應該使用 React 進行 Redux。

為什么要使用 Redux?

使用 Redux 和 React 消除了管理狀態的麻煩,讓你更容易追蹤哪個動作導致了任何變化,從而簡化了應用程序并使其更容易維護。

讓我們來看看使用 Redux 進行狀態管理帶來的一些權衡。

(1) 社區支持

作為 React 和 Redux 的官方綁定庫,React-Redux 包含了龐大的用戶社區。這使得尋求幫助、了解最佳實踐、使用基于 React-Redux 構建的庫以及在不同應用程序中重用您的知識變得更加容易。

它是 Github 上最受關注的 React 狀態管理庫。

(2) 增強性能

React Redux 確保性能優化,以便只有連接的組件僅在需要時重新渲染;因此保持應用程序的狀態全局不會導致任何問題。

(3) Redux 使狀態可預測

在 Redux 中,狀態始終是可預測的。如果相同的 state 和 action 移動到 reducer,它會得到相同的結果,因為 reducer 是純函數。狀態也是不可變的,永遠不會改變。它使執行諸如無限撤消和重做之類的艱巨任務成為可能。還可以實現時間旅行——即在之前的狀態之間來回移動并實時查看結果的能力。

(4) 本地存儲上的狀態持久性

將應用程序的某些狀態保留在本地存儲上并在刷新后恢復它是可能的。它使得在本地存儲上存儲諸如購物車數據之類的東西真的很棒。

(5) 服務端渲染

我們也可以使用redux進行服務端渲染。有了它,您可以通過將應用程序的狀態連同它對服務器請求的響應發送到服務器來處理應用程序的初始呈現。

(6) Redux 是可維護的

Redux 對代碼應該如何設計很嚴格,這使得熟悉 Redux 的人更容易理解任何 Redux 應用程序結構。它通常更易于維護。它還可以幫助您將業務邏輯與組件樹分離。對于大型應用程序,讓您的應用程序更具可預測性和可維護性至關重要。

(7) 調試變得容易

Redux 使調試應用程序變得容易。通過記錄操作和狀態,很容易理解編碼錯誤、網絡錯誤和生產過程中可能出現的其他形式的錯誤。

除了日志之外,它還有優秀的 DevTools,可以讓你對動作進行時間旅行,在頁面刷新時保持動作等。對于中大型應用程序,調試比實際開發功能需要更多的時間。

盡管 Redux 有其優點,但并不保證您在所有應用程序中都添加了 Redux。

您的應用程序可以在沒有 Redux 的情況下運行良好。

Recoil

Recoil 似乎是狀態管理社區的最新工具——一個擁有大量優秀庫的社區,如 Context、Mobx 和 Redux 等。

在詳細介紹 Recoil 之前,我想指出這個新的狀態管理庫并不是 React 的“官方”狀態管理庫。

然而,記錄顯示它是由 Facebook 團隊的工程師,即 React 創建者構建和發布的。

但是,正如 Redux 不是 React 的官方狀態管理庫一樣,Recoil 也不是,但如果它被證明對整個 React 生態系統有價值,那么它可能會被 React 愛好者廣泛采用。

Recoil 解決的主要問題

雖然它有它的學習曲線,但它仍然解決與大多數其他狀態管理庫相同的問題:全局狀態管理。

在使用 Recoil 一段時間后,以下是我認為 Recoils 非常方便的區別。

(1) 類似 React 的方法和簡單

Recoil 的簡單性是首屈一指的,因此它在此列表中的原因。

您可以像使用 Redux 或 MobX 一樣構建使用 Recoil 構建的任何應用程序。

然而,Recoil 感覺就像在使用 React 的 useState 的全球版本。它還支持并發模式,這是一個巨大的優勢(在撰寫本文時仍在進行中)。

(2) 簡單的學習曲線

Recoil 不像 Redux 和 Mobx 那樣強加嚴格的學習曲線。

除了易于理解的 Atom 和 Selectors 之外,它們不需要學習太多。

(3) 應用程序范圍的觀察

與其他狀態管理庫類似,Recoil 可以很好地處理應用程序范圍的狀態觀察。使用 Recoil 的其他好處包括:

  • 無樣板 API
  • 分布式和增量狀態定義

Recoil 的核心核心概念是原子和選擇器;涵蓋這一部分超出了本文的范圍。但是,您可以查看他們的文檔以獲得深入的概述。

何時使用Recoil

在發布不到兩年的時間里,Recoil 已經發展得如此之快,以至于在撰寫本文時,它在 Github 上擁有大約 12,000 顆星。除此之外,它在 React 愛好者和整個 React 社區中逐漸獲得動力和大規模采用。

就個人而言,我在我的任何項目中使用 Recoil 的唯一原因是我不打算在我的代碼庫中有這么多 Redux 樣板。我曾經在生產中使用過 Recoil,沒有發生任何可怕的事情;到目前為止,一切仍然運行良好。

所以什么時候使用 Recoil 可能完全取決于你的應用程序的架構決定,如果你和我一樣喜歡簡單,你可能會開始使用 Recoil 。

使用 React Hooks

Hooks 是 React 庫自創建以來添加的最杰出的特性之一。Hooks 為功能組件帶來了“狀態”。現在,功能組件可以自己創建和管理本地狀態,就像類組件一樣。

任何已經接觸過 React 的人都應該熟悉 React Hooks,包括useState、useEffect、 和useReducer等。

本節將討論如何方便的 React Hooks 可以獨立使用,而無需與任何外部狀態管理庫相互干擾。

你可以在沒有任何庫的情況下使用 React Hooks 作為你的主要狀態管理工具,但這取決于你對 React Hooks 的經驗和理解。

它們本身就很強大,幾乎可以完成外部庫可以做的任何事情。

在某種程度上,其他狀態管理工具具有一些優勢。盡管如此,他們的程序使入門具有挑戰性。就像 Redux 一樣,需要一些樣板代碼才能讓它在我們的應用程序中工作;因此,它引入了不必要的復雜性。

另一方面,使用useContextAPI 和 React Hooks,無需安裝外部庫即可讓我們的應用程序正常運行。它使它成為一種更簡單、更直接的方式來處理 React 應用程序中的全局狀態管理。

注意:假設您已經熟悉useState,我們將研究兩個有助于 React 狀態管理過程的Hooks。

useReducer

該useReducer來自React 16.8。就像reduce() JavaScript 中的方法一樣,useReducerHook 接收兩個值作為它的參數——一個 reducer 函數和一個初始狀態——然后返回一個新狀態:

  1. const [state, dispatch] = useReducer((state, action) => { 
  2.   const { type } = action; 
  3.   switch(action) { 
  4.     case 'action description': 
  5.       const newState = // do something with the action 
  6.       return newState; 
  7.     default: 
  8.       throw new Error() 
  9.   } 
  10. }, []); 

在上面的代碼片段中,我們定義了我們的狀態和相應的方法dispatch,來處理它。當我們調用該dispatch方法時,useReducer() Hook 將根據type我們的方法在其 action 參數中接收到的來執行操作:

  1. ... 
  2. return ( 
  3.   <button onClick={() => 
  4.     dispatch({ type: 'action type'})}> 
  5.   </button> 

使用上下文

此鉤子用于獲取 Provider 的當前上下文。為了創建和提供上下文,我們使用React.createContextAPI。

  1. const myContext = React.createContext() 

我們將根組件放在myContextProvider之間:

  1. function App() { 
  2.     return ( 
  3.         <myContext.Provider value={900}> 
  4.             <Root /> 
  5.         </myContext.Provider> 
  6.     ) 

為了消耗由我們提供的值,我們使用useContext鉤子。

  1. function Root() { 
  2.     const value = useContext(myContext) 
  3.     return ( 
  4.         <div> 
  5.             <h3>My Context value: {value} </h3> 
  6.         </> 
  7.     ) 

使用 useReducer 和 useContext

將 useContext 與 useReducer 一起使用可以在另一個級別上將組件并置狀態管理。突然間,我們可以將 useReducer 創建的狀態容器及其調度函數從任何頂級組件傳遞給任何組件。它也可以是使狀態“全局化”的最頂層組件。也可以僅使用 React props 向下傳遞內容,但是 React 的 Context API 使您的狀態和調度函數可以在任何地方使用,而無需顯式地將所有內容向下傳遞到組件樹。

結論

在本文中,我們試圖介紹 2021 年最流行的 React 狀態管理工具,它們如何在 React 狀態管理中發揮重要作用,以及何時在項目中使用它們。

我想知道您在典型 React 應用程序中管理狀態的經驗。

 

責任編輯:趙寧寧 來源: 今日頭條
相關推薦

2021-09-28 09:00:00

開發JavaScript存儲

2024-04-22 09:12:39

Redux開源React

2020-10-09 11:50:10

ReactRecoil前端

2020-11-13 15:40:18

React前端Recoil

2021-07-26 09:00:08

ReactHooks 項目

2019-03-13 10:10:26

React組件前端

2020-06-12 08:22:27

React ReduxReact開發

2024-04-25 09:10:50

ReactReduxJavaScript

2019-08-20 15:16:26

Reacthooks前端

2023-11-06 08:00:00

ReactJavaScript開發

2022-03-18 14:09:52

ReactJavaScript

2024-01-08 09:36:47

管理庫代碼

2020-10-28 09:12:48

React架構Hooks

2021-11-04 10:35:16

開源項目React

2021-03-18 08:00:55

組件Hooks React

2021-12-17 19:15:51

前端蟲洞狀態

2022-03-31 17:54:29

ReactHooks前端

2020-09-19 17:46:20

React Hooks開發函數

2022-04-21 08:01:34

React框架action

2024-02-05 21:48:25

VueReactHooks
點贊
收藏

51CTO技術棧公眾號

亚洲欧美激情在线| 日韩欧美在线视频日韩欧美在线视频 | 国产白丝袜美女久久久久| 好吊妞视频这里有精品 | 国产又粗又长又爽视频| 97精品国产| 欧美黑人xxx| 福利视频在线| 精品欧美一区二区三区| 国产羞羞视频在线观看| 国产一区二区三区国产| 欧美在线一区二区三区四区| 国内一区二区三区| 国产97色在线|日韩| 久久中文字幕一区二区| 一区二区三区高清国产| 激情成人四房播| 色噜噜夜夜夜综合网| 免费观看羞羞视频网站| 26uuu国产电影一区二区| 特级西西444| 国产精品一区2区| 无码人妻aⅴ一区二区三区日本| 亚洲激情自拍| 麻豆91av| 奇米色一区二区| 亚洲一区不卡在线| 精品一区二区在线观看| av在线免费观看国产| 91亚洲永久精品| 黑人粗进入欧美aaaaa| 亚洲人成在线播放网站岛国| 嫩草影院网站在线| 色88888久久久久久影院野外| 国产三区四区在线观看| 欧美日韩国产免费一区二区| 在线a人片免费观看视频| 亚洲国产成人爱av在线播放| 中文另类视频| 久久久久久久久久久网站| 99精品在线| 在线视频亚洲自拍| 国产女主播一区| 国产一级粉嫩xxxx| 51精品视频一区二区三区| 国产精品伦一区二区| 国产不卡精品视男人的天堂| 国产欧美69| 亚洲第一av网| 福利网在线观看| 亚洲春色在线视频| 日本一区二区在线不卡| 日韩欧美不卡在线| 亚洲一区二区三区三| 在线中文字幕视频观看| 日韩精品亚洲元码| 精品在线小视频| 欧美电影完整版在线观看| 成人日韩在线电影| 激情文学综合插| 青青草在线播放| 欧美成人在线免费| 日韩vs国产vs欧美| 羞羞小视频在线观看| 亚洲精品在线91| 欧美成人综合| 孩娇小videos精品| 俺也去精品视频在线观看| 亚洲欧美日韩视频二区| 国产免费福利| 国产午夜精品一区二区三区 | 国产中文字幕在线看| 欧美情侣性视频| 国产在线视频不卡二| 欧美黄色激情| 91久久精品一区二区别| 亚洲激情成人在线| 亚洲成人av观看| 最新欧美日韩亚洲| 精品处破学生在线二十三| 亚洲成人一区| 国模精品一区二区| 国产伦精品一区二区三区高清| 一二三区精品福利视频| 亚洲精品一区国产| 91免费日韩| 国产欧美精品日韩精品| 亚洲国产欧美一区二区三区丁香婷| 午夜日韩影院| 一级片a一级片| 91精品久久久久久久久久| 亚洲www啪成人一区二区麻豆| 99tv成人| a级网站在线播放| 亚洲精品中文字幕在线| 亚洲欧美国产一区二区三区| 成人一区二区在线观看| 久久a级毛片毛片免费观看| 激情五月婷婷久久| 国产精品二区二区三区| 欧美变态口味重另类| 成人激情文学综合网| 免费一区二区| 午夜视频在线看| 免费av观看网址| 国产成人精品久久二区二区91 | 国产一区二区三区直播精品电影| 久久精品无码一区二区三区| 国产亚洲一卡2卡3卡4卡新区| 粉嫩av在线播放| 日韩a级在线观看| 91精品视频在线| 国产一区二区三区中文| 亚洲综合激情小说| 99久久综合精品| 中文字幕一区二区三区久久网站| eeuss鲁一区二区三区| 91日韩视频在线观看| 国产精品美女黄网| 久久久久国产视频| 亚洲电影免费观看高清| 精品久久久久久国产| 丁香亚洲综合激情啪啪综合| 99精品免费| 欧美精品一区二区三区中文字幕 | 福利在线导航136| 天天av综合网| 久草香蕉在线| 日韩欧美不卡在线| 亚洲精品9999| 日本精品一区二区三区视频| 国产在线高清精品| 久久久在线视频| 久久天堂电影网| 国产亚洲免费的视频看| 日韩h在线观看| 亚洲欧美成人网| 欧美另类z0zxhd电影| 色8久久人人97超碰香蕉987| 亚洲午夜精品网| 狠狠躁夜夜躁人人爽超碰91| 亚洲国产日日夜夜| 欧美日韩国产一二三| 91精品国产高清一区二区三区| 欧美精选午夜久久久乱码6080| 欧美性xxxx极品hd满灌| 欧美日韩国产黄| 欧美日韩视频在线第一区| 在线观看91视频| 欧美本精品男人aⅴ天堂| 亚洲国产欧美一区| 精品综合久久久久久97| 91丝袜呻吟高潮美腿白嫩在线观看| 国产欧美视频在线观看| 一区二区三区精品视频| 在线观看亚洲一区| 日韩大片免费观看视频播放| 中文字幕亚洲欧美一区二区三区| 欧美成人合集magnet| 91丝袜脚交足在线播放| 久久国产精品久久精品国产| 超碰97在线看| 伊人色综合久久| 成人影音在线| 久久九九热re6这里有精品| 99久久www免费| 懂色av一区二区在线播放| 一区二区三区在线视频播放| 欧美午夜影院一区| 久久精品动漫| 国产女人18毛片水真多18精品| 欧美va天堂| 国产成人日日夜夜| 中文字幕一区二区三| 精品国产污网站| 国产成人精品优优av| 欧美日韩精品免费看| 青青青在线视频免费观看| 日本成人网址| 最新精品国偷自产在线| 黄网站免费久久| 精品日韩中文字幕| 久久在线精品视频| 亚洲精品国产精品国自产观看| 人猿泰山h版在线观看| www成人在线视频| 最新国产乱人伦偷精品免费网站| 国产精品丝袜久久久久久app| 日韩av在线影院| 国产乱码精品一区二区三区日韩精品 | 在线观看欧美日本| 日韩美女免费线视频| 久久久久久久少妇| 日韩欧美一区二区三区免费观看| 一区二区国产精品| 在线视频你懂得一区| 国产成人福利网站| 成人网免费看| 欧美色资源站| 综合久久给合久久狠狠狠97色|