React+Redux-Saga+Seamless-Immutable+Reduxsauce后臺(tái)系統(tǒng)搭建之路(一)

最近公司需要重構(gòu)一個(gè)后臺(tái)管理系統(tǒng)灼捂,原因就是用到的技術(shù)比較過時(shí)渤涌,例如:react的版本是0.14.7片吊,antd的版本還是0.12.4绽昏。
之前嘗試重構(gòu)了一個(gè)頁面,這個(gè)頁面的數(shù)據(jù)非常復(fù)雜俏脊,老的代碼解決的方案往往是context全谤,對(duì)于這種方式,官網(wǎng)給出了一個(gè)Notice:


Note.png

我理解的這段話的意思應(yīng)該是首先不要濫用爷贫,這樣會(huì)產(chǎn)生很多magic number從而讓代碼閱讀都不知所云认然,使用context的場(chǎng)景往往應(yīng)該是有一個(gè)父組件管理很多數(shù)據(jù)來讓它的子組件們共享這些數(shù)據(jù)补憾。
這種方式很容易讓人聯(lián)想到了redux,為了管理這些復(fù)雜的數(shù)據(jù)卷员,我在下一個(gè)頁面中使用了React+Redux-Saga+Seamless-Immutable+Reduxsauce這樣的一種架構(gòu)方式盈匾。

為什么要這么做

Redux

You Might Not Need Redux,當(dāng)你不知道你是否需要Redux的時(shí)候毕骡,那你就是不需要它削饵。我們?cè)谑褂胷edux實(shí)現(xiàn)一個(gè)功能的時(shí)候,往往需要修改三個(gè)文件:1未巫、View層dispatch一個(gè)action窿撬;2、Controller層收到這個(gè)action并執(zhí)行一些邏輯叙凡,dispatch一個(gè)action給Modal層尤仍;3、Modal層處理數(shù)據(jù)狭姨。
而在我新開發(fā)的這個(gè)頁面中,涉及到了一些非常復(fù)雜的情況:多種用戶(供應(yīng)商苏遥、子商戶)饼拍、多種模式(正常報(bào)名、修改報(bào)名)田炭,以及要修改一些粒度非常小的數(shù)據(jù)(為一個(gè)商戶關(guān)聯(lián)商品并將商品信息展示出來师抄,修改關(guān)聯(lián)的商品的圖片等)。拿到這種需求的時(shí)候教硫,我第一時(shí)間就想到了必須使用這個(gè)工具叨吮,否則數(shù)據(jù)的龐大和復(fù)雜會(huì)讓我陷入惡夢(mèng)之中。

saga

起初我只是想學(xué)習(xí)調(diào)研一種新的使用redux的方式瞬矩〔杓可是隨著學(xué)習(xí)的深入和使用得越來越多,我對(duì)它越發(fā)著迷景用。saga其實(shí)是redux的一個(gè)中間件涵叮,它提供了非常優(yōu)秀的異步處理方式,就是使用Generator函數(shù)來讓Promise調(diào)用扁平化伞插,像編寫同步代碼一樣編寫異步代碼割粮。其次,saga還提供了很多優(yōu)秀的方法來控制流程媚污,如:fork執(zhí)行一個(gè)非阻塞操作舀瓢;Race 同步執(zhí)行多個(gè) effect,然后一旦有一個(gè)完成耗美,取消其他 effect京髓;takeLatest 意味著我們將執(zhí)行所有操作航缀,然后返回最后一個(gè)(the latest one)調(diào)用的結(jié)果。如果我們觸發(fā)了多個(gè)時(shí)間朵锣,它只關(guān)注最后一個(gè)(the latest one)返回的結(jié)果等谬盐。不僅如此,我從中還摸索到的一種“鎖”的概念(后面會(huì)講到诚些,這種方法對(duì)于 redux化的Stateless Component非常有用飞傀,可以用來模擬生命周期函數(shù)而無需使用高階函數(shù))。

Seamless-Immutable

Shared mutable state is the root of all evil(共享的可變狀態(tài)是萬惡之源)
-- Pete Hunt

我們都知道react的state是不可變的诬烹,修改state的時(shí)候(特別是引用類型)不能直接使用this.state.foo.bar = newValue砸烦,因?yàn)镽eact的diff算法是shallow eqaul的。我們可以通過cloneDeep來深拷貝原state绞吁,再修改這個(gè)拷貝出來的新值幢痘,再setState。
或者使用Seamless-Immutable來解決這個(gè)問題家破。一個(gè)immutable值一旦生成就不可改變颜说,只要對(duì)這個(gè)值進(jìn)行有副作用的操作都會(huì)生成一個(gè)新的值。同時(shí)Immutable值會(huì)采用結(jié)構(gòu)共享汰聋,即如果對(duì)象樹中一個(gè)節(jié)點(diǎn)發(fā)生變化门粪,只修改這個(gè)節(jié)點(diǎn)和受它影響的父節(jié)點(diǎn),其它節(jié)點(diǎn)則進(jìn)行共享烹困。這樣也避免了cloneDeep帶來的性能消耗玄妈。如果每次都生成一個(gè)新的對(duì)象,那么就可以把這些對(duì)象存儲(chǔ)下來髓梅,實(shí)現(xiàn)時(shí)間旅行就非常簡單了拟蜻。

immutable.gif
圖片來源

Reduxsauce

這個(gè)工具主要是用來簡化reducer的寫法,避免判斷action.type而產(chǎn)生的無數(shù)switch...case...枯饿,以及可以非常輕松地生產(chǎn)出不重復(fù)的action.type等功能酝锅。

if you trade something off, make sure you get something in return.(如果你付出了一些東西,一定要確保你能獲得一些東西)奢方,以上介紹了技術(shù)選型的原因屈张,一定不要為了使用技術(shù)而使用技術(shù),帶著明確的目標(biāo)袱巨,下面介紹一下這套系統(tǒng)的搭建方法阁谆。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市愉老,隨后出現(xiàn)的幾起案子场绿,更是在濱河造成了極大的恐慌,老刑警劉巖嫉入,帶你破解...
    沈念sama閱讀 217,084評(píng)論 6 503
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件焰盗,死亡現(xiàn)場(chǎng)離奇詭異璧尸,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)熬拒,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,623評(píng)論 3 392
  • 文/潘曉璐 我一進(jìn)店門爷光,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人澎粟,你說我怎么就攤上這事蛀序。” “怎么了活烙?”我有些...
    開封第一講書人閱讀 163,450評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵徐裸,是天一觀的道長。 經(jīng)常有香客問我啸盏,道長重贺,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,322評(píng)論 1 293
  • 正文 為了忘掉前任回懦,我火速辦了婚禮气笙,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘怯晕。我一直安慰自己潜圃,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,370評(píng)論 6 390
  • 文/花漫 我一把揭開白布贫贝。 她就那樣靜靜地躺著,像睡著了一般蛉谜。 火紅的嫁衣襯著肌膚如雪稚晚。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,274評(píng)論 1 300
  • 那天型诚,我揣著相機(jī)與錄音客燕,去河邊找鬼。 笑死狰贯,一個(gè)胖子當(dāng)著我的面吹牛也搓,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播涵紊,決...
    沈念sama閱讀 40,126評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼傍妒,長吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來了摸柄?” 一聲冷哼從身側(cè)響起颤练,我...
    開封第一講書人閱讀 38,980評(píng)論 0 275
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎驱负,沒想到半個(gè)月后嗦玖,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體患雇,經(jīng)...
    沈念sama閱讀 45,414評(píng)論 1 313
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,599評(píng)論 3 334
  • 正文 我和宋清朗相戀三年宇挫,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了苛吱。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 39,773評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡器瘪,死狀恐怖翠储,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情娱局,我是刑警寧澤彰亥,帶...
    沈念sama閱讀 35,470評(píng)論 5 344
  • 正文 年R本政府宣布,位于F島的核電站衰齐,受9級(jí)特大地震影響任斋,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜耻涛,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,080評(píng)論 3 327
  • 文/蒙蒙 一废酷、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧抹缕,春花似錦澈蟆、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,713評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至奏赘,卻和暖如春寥闪,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背磨淌。 一陣腳步聲響...
    開封第一講書人閱讀 32,852評(píng)論 1 269
  • 我被黑心中介騙來泰國打工疲憋, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人梁只。 一個(gè)月前我還...
    沈念sama閱讀 47,865評(píng)論 2 370
  • 正文 我出身青樓缚柳,卻偏偏與公主長得像,于是被迫代替她去往敵國和親搪锣。 傳聞我的和親對(duì)象是個(gè)殘疾皇子秋忙,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,689評(píng)論 2 354

推薦閱讀更多精彩內(nèi)容