使用react-redux 實現(xiàn)todolist記錄

注意:擴展 指的是實現(xiàn)一個類似于 奇妙清單 的todos的思考

先設(shè)計Redux 的 state

根據(jù)應(yīng)用的功能來設(shè)計state的數(shù)據(jù)存儲結(jié)構(gòu)
對于一個todos畜疾,有兩個數(shù)據(jù)需要存儲:

  1. 過濾器(就是當(dāng)前選擇顯示的todos)纱皆,如:顯示所有的todos杰妓、顯示未完成的todos或者顯示完成的todos
  2. todos的信息
- text
- completed
- deleted

Redux state的數(shù)據(jù)結(jié)構(gòu)就是:

{
  visibilityFilter: 'SHOW_ALL',
  todos: [
    {
      text: 'Consider using Redux',
      completed: true,
    },
    {
      text: 'Keep all state in a single tree',
      completed: false
    }
  ]
}

擴展

  1. 過濾器
  2. todos的信息
- text:todo的信息
- folder:該todo所屬folder
- completed:完成狀態(tài)
- deleted:刪除狀態(tài)
- createTime:創(chuàng)建時間
- finishedTime::完成時間

設(shè)計component層級(Hierarchy)

Think in React

設(shè)計一個web app 的流程

第一步:將UI解剖到 Component Hierarchy中

在這個過程中突诬,應(yīng)該如何將UI解剖成單個的組件呢顿苇?或者說我們?nèi)绾未_定這一部分可以作為一個組件存在界酒?
遵循一個原則:單一職責(zé)原則葵第,也就是說一個組件只做一件事
一般來說绘迁,如果數(shù)據(jù)模型合理,那么就很好將數(shù)據(jù)模型映射到UI組件上羹幸,因為UI和數(shù)據(jù)模型一般都是遵循相同的架構(gòu)脊髓,所以,只需要將數(shù)據(jù)模型分解為代表UI的各個組件即可

將UI拆分為各個組件之后栅受,要畫出組件層級圖将硝,表明各組件的層級關(guān)系,也就是它們之間是如何進行嵌套的

第二步:Build A Static Version in React

就是將第一步劃分的component屏镊,按照Component 層級關(guān)系拼接成一個沒有交互的版本;
注意:不要使用state來構(gòu)建該版本依疼,state僅僅是為了交互而存在的

構(gòu)建該版本有兩種方式:

  • 依照component Hierarchy從頂向下構(gòu)建,也就是從最上層的組件開始編寫
  • 從下向上構(gòu)建而芥,從最底層的組件開始編寫
    對于簡單項目來說律罢,采用從頂向下比較好,而對于復(fù)雜應(yīng)用來說棍丐,使用從下向上更加適合

數(shù)據(jù)從最頂層的component與data model進行通信误辑,然后通過props向下面的子組件傳遞數(shù)據(jù)
React遵循單向數(shù)據(jù)流

最頂層的組件一般都是Container component,而它下面的子組件很大一部分都是Presentation component歌逢。

第三步:構(gòu)建能夠反映UI狀態(tài)的最小數(shù)據(jù)模型(state)

其實就是設(shè)計數(shù)據(jù)存儲框架贩疙,也就是model的架構(gòu)

在React中有兩種數(shù)據(jù)模型(model):propsstate

這時讨永,我們要判斷出我們的應(yīng)用程序中盖溺,哪些是state莫鸭,哪些是props潦匈?
首先,列出我們的應(yīng)用程序所有的數(shù)據(jù)
然后依照下面的規(guī)則來判斷哪些數(shù)據(jù)是state赚导,規(guī)則如下:

  • 如果這個數(shù)據(jù)是父組件通過props傳遞下來的茬缩,那么該數(shù)據(jù)就不屬于state
  • 如果該數(shù)據(jù)隨著時間保持不變,那么它很可能不屬于state
  • 該數(shù)據(jù)是否能通過你組件中的其他state或props計算出來吼旧,如果可以凰锡,它很可能不是state

第四步:標(biāo)識出state應(yīng)該傳遞給哪些組件

對于新手,這一步往往會很困惑黍少,可以遵循下面的幾條規(guī)則:

  • 如果一個組件需要依靠該state來進行刷新寡夹,那么你需要將state傳遞給它
  • 在component hierarchy中,層次結(jié)構(gòu)較高的組件可能需要改state

第五步:增加逆向數(shù)據(jù)流

因為子組件不能直接更改父組件傳遞下來的數(shù)據(jù)厂置,所以菩掏,需要為子組件的行為綁定事件處理程序,該處理程序通過父組件傳遞下去

參考:https://facebook.github.io/react/docs/thinking-in-react.html

使用Redux 和 React

在上面的構(gòu)建出了最小數(shù)據(jù)模型之后要開始設(shè)計Redux的actions和reducer

接上面的第三步之后昵济,設(shè)置actions

設(shè)計reducer

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末智绸,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子访忿,更是在濱河造成了極大的恐慌瞧栗,老刑警劉巖,帶你破解...
    沈念sama閱讀 219,427評論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件海铆,死亡現(xiàn)場離奇詭異迹恐,居然都是意外死亡,警方通過查閱死者的電腦和手機卧斟,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,551評論 3 395
  • 文/潘曉璐 我一進店門殴边,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人珍语,你說我怎么就攤上這事锤岸。” “怎么了板乙?”我有些...
    開封第一講書人閱讀 165,747評論 0 356
  • 文/不壞的土叔 我叫張陵是偷,是天一觀的道長。 經(jīng)常有香客問我募逞,道長蛋铆,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,939評論 1 295
  • 正文 為了忘掉前任放接,我火速辦了婚禮刺啦,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘透乾。我一直安慰自己洪燥,他們只是感情好,可當(dāng)我...
    茶點故事閱讀 67,955評論 6 392
  • 文/花漫 我一把揭開白布乳乌。 她就那樣靜靜地躺著捧韵,像睡著了一般。 火紅的嫁衣襯著肌膚如雪汉操。 梳的紋絲不亂的頭發(fā)上再来,一...
    開封第一講書人閱讀 51,737評論 1 305
  • 那天,我揣著相機與錄音磷瘤,去河邊找鬼芒篷。 笑死,一個胖子當(dāng)著我的面吹牛采缚,可吹牛的內(nèi)容都是我干的针炉。 我是一名探鬼主播,決...
    沈念sama閱讀 40,448評論 3 420
  • 文/蒼蘭香墨 我猛地睜開眼扳抽,長吁一口氣:“原來是場噩夢啊……” “哼篡帕!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起贸呢,我...
    開封第一講書人閱讀 39,352評論 0 276
  • 序言:老撾萬榮一對情侶失蹤镰烧,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后楞陷,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體怔鳖,經(jīng)...
    沈念sama閱讀 45,834評論 1 317
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,992評論 3 338
  • 正文 我和宋清朗相戀三年固蛾,在試婚紗的時候發(fā)現(xiàn)自己被綠了结执。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 40,133評論 1 351
  • 序言:一個原本活蹦亂跳的男人離奇死亡魏铅,死狀恐怖昌犹,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情览芳,我是刑警寧澤斜姥,帶...
    沈念sama閱讀 35,815評論 5 346
  • 正文 年R本政府宣布,位于F島的核電站沧竟,受9級特大地震影響铸敏,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜悟泵,卻給世界環(huán)境...
    茶點故事閱讀 41,477評論 3 331
  • 文/蒙蒙 一杈笔、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧糕非,春花似錦蒙具、人聲如沸球榆。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,022評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽持钉。三九已至,卻和暖如春篱昔,著一層夾襖步出監(jiān)牢的瞬間每强,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,147評論 1 272
  • 我被黑心中介騙來泰國打工州刽, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留空执,地道東北人。 一個月前我還...
    沈念sama閱讀 48,398評論 3 373
  • 正文 我出身青樓穗椅,卻偏偏與公主長得像辨绊,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子匹表,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 45,077評論 2 355

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

  • 做React需要會什么桑孩? react的功能其實很單一拜鹤,主要負責(zé)渲染的功能,現(xiàn)有的框架流椒,比如angular是一個大而...
    蒼都閱讀 14,760評論 1 139
  • 一敏簿、什么情況需要redux? 1宣虾、用戶的使用方式復(fù)雜 2惯裕、不同身份的用戶有不同的使用方式(比如普通用戶和管...
    初晨的筆記閱讀 2,030評論 0 11
  • 前言 本文 有配套視頻,可以酌情觀看绣硝。 文中內(nèi)容因各人理解不同蜻势,可能會有所偏差,歡迎朋友們聯(lián)系我討論鹉胖。 文中所有內(nèi)...
    珍此良辰閱讀 11,906評論 23 111
  • 學(xué)習(xí)必備要點: 首先弄明白握玛,Redux在使用React開發(fā)應(yīng)用時,起到什么作用——狀態(tài)集中管理 弄清楚Redux是...
    賀賀v5閱讀 8,902評論 10 58
  • 通俗地講甫菠,代碼的健壯性越好挠铲,系統(tǒng)越不容易崩潰。 系統(tǒng)的運行寂诱,肯定會基于很多基礎(chǔ)設(shè)施拂苹,如:操作系統(tǒng)、數(shù)據(jù)庫痰洒、異步隊列...
    ChaserChen閱讀 2,375評論 0 0