今天就跟大家聊聊有關怎樣解析React 狀態(tài)管理,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結了以下內容,希望大家根據(jù)這篇文章可以有所收獲。
網(wǎng)站建設哪家好,找創(chuàng)新互聯(lián)!專注于網(wǎng)頁設計、網(wǎng)站建設、微信開發(fā)、重慶小程序開發(fā)、集團企業(yè)網(wǎng)站建設等服務項目。為回饋新老客戶創(chuàng)新互聯(lián)還提供了合川免費建站歡迎大家使用!
社區(qū)中對 React 狀態(tài)管理方案的討論從未停息過,特別是自從 Hooks 誕生以來,各種“新穎”的狀態(tài)管理方案層出不窮,為了能更理性的看待這個問題,我們不妨把那些具體的框架/庫都拋在腦后,先來聊一聊,抽象層面上的“狀態(tài)管理”到底意味著什么。
?給一個抽象的東西下定義,是非常難的。例如我們在討論“書是什么”時,有些人可能會認為書就是紙張構成的一本印刷冊,可有的人認為手寫的一本稿子也算是書,而又有的人會認為電子產品中的一部文字的集合也算是廣義上的書??照劯拍畹亩x是沒有什么意義的,很多概念的邊界是模糊的,與其浪費時間去爭出一個大家都認同的“邊界”,不如先找出一個粗略的定義,畢竟我們只是想借助對定義的探討,來反觀現(xiàn)實。
?
在我個人的觀念里,狀態(tài)管理主要有兩個方面的職能:
不知道這是不是 redux 或 mobx 的初衷,但這確實是我一直以來對狀態(tài)管理工具的“「痛點需求」”。
那么接下來,我們不妨在這兩個方面分別討論:
既然要共享數(shù)據(jù),那么最簡單粗暴的方案就是直接做成「全局」性的(redux 也確實是這么做的),于是很多人的都漸漸形成了一種認知:React 應用中的狀態(tài)有兩種,一種是組件內部的(this.state / useState),另一種是全局的(redux)。但是,「內部狀態(tài)」的反義詞從來都不是「全局狀態(tài)」,而是「共享狀態(tài)」,全局只是共享的一種途徑罷了,并不能成為其本身。
目前來看,在組件間進行狀態(tài)的共享,有兩種比較可靠的途徑,其一就是剛剛提到的「全局狀態(tài)共享」,而另一種,也是我個人更加傾向的,是「局部狀態(tài)共享」。React 提供了非常簡潔易用的 Context API,用于在一個組件樹中共享數(shù)據(jù),局部狀態(tài)共享的思路大致就是來自于此,在一個組件樹(而非整個應用)內進行數(shù)據(jù)共享。
可是這樣做又能有什么好處呢?
當然,反對的聲音也是存在的:
其實大家不難發(fā)現(xiàn),局部狀態(tài)中“局部”是可大可小的,不論是小至包裹在一個組件外面(雖然不會有人真的這樣寫代碼),還是包裹到整個應用外面,都可以稱之為“局部”。因此準確的講,全局狀態(tài)只是局部狀態(tài)的一個「子集」、一個「特例」。局部狀態(tài)這種模式,只是把枷鎖解掉了,并非和全局狀態(tài)互斥。
我覺得狀態(tài)管理中真正的痛點在于“和數(shù)據(jù)相粘連的邏輯”如何組織,而 Hooks 提供了一整套完備的管理邏輯的方案,從狀態(tài)到副作用到性能優(yōu)化到異步。
在以前,對于組件內部的狀態(tài),邏輯組織能力是非常薄弱的,因此很多人求助于把狀態(tài)抽到外部(例如 redux),因為外部的狀態(tài)管理器中可以更好的組織業(yè)務邏輯。甚至更極端的,會試圖把整個應用狀態(tài)都放在 redux 中,而 React 組件內不允許保留狀態(tài)。
但是 Hooks 的誕生讓組件內部狀態(tài)的邏輯組織能力得到了大幅提升,我覺得是完全不輸甚至更強于 flux 模式的。如果我們能夠把組件內部狀態(tài)和共享狀態(tài)全部都用 Hooks 進行組織,那我們就再也不需要對一份數(shù)據(jù)該存放在哪里而感到糾結了,因為我們只需要關心一點:這份數(shù)據(jù)被誰需要了?是只有這個組件自己,還是多個組件之間?
Hooks 不是為了狀態(tài)管理而生的,但卻可以深刻地改變整個生態(tài)。就像智能手機不是為了購物而生的,但卻可以顛覆人們的消費和生活方式。
狀態(tài)管理之所以一直以來被人們特意強調,一定程度上恰恰是因為它的格格不入,需要被人們去單獨學習和特別注意。如果大膽猜測一下的話,我會覺得在不久的將來,我們之前熱衷于討論的“狀態(tài)管理”這個詞,會更多的意味著“狀態(tài)共享”,甚至于銷聲匿跡。一個 React 應用的狀態(tài)構成也會從“組件內的狀態(tài) + 狀態(tài)管理器中的狀態(tài)”變成“組件內的狀態(tài)+組件間共享的狀態(tài)”。
看完上述內容,你們對怎樣解析React 狀態(tài)管理有進一步的了解嗎?如果還想了解更多知識或者相關內容,請關注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝大家的支持。