Redux學(xué)習(xí)

Redux概念:一個(gè)幫助我們管理State的容器,是javaScript的狀態(tài)容器荡灾,提供了可預(yù)測的狀態(tài)管理瓤狐;
redux中的reducer概念:要求是一個(gè)純函數(shù)(確定的輸入,一定會(huì)有確定的輸出批幌;沒有產(chǎn)生副作用)
比如:slice(純函數(shù))础锐、splice會(huì)對(duì)原來的數(shù)組修改,不是一個(gè)純函數(shù).
所有React組件都必須像純函數(shù)一樣保護(hù)它們的props不被修改

  • 核心理念:Store
  • 核心理念:action

所有的數(shù)據(jù)變化荧缘,必須通過派發(fā)(dispath)action來更新
action:是一個(gè)普通的javascript對(duì)象皆警,用來描述這次更新的type和content

const aciont1 = { type:"INC_AGE", index:0 }
const aciont2 = { type:"CHANGE_NAME", playload:{index:0,newName:"haha"} }
  • 核心理念:reducer
  1. 是一個(gè)純函數(shù)
  2. 做的事情就是將傳入的state和action結(jié)合起來生成一個(gè)新的state
function reducer(state = initialState, action) {
  switch (action.type) {
    case "INC_AGE":
      return { ...state, counter: state.counter + action.num }
    case "CHANGE_NAME":
      return { ...state, counter: state.counter - action.num }
    default:
      return state
  }
}
export default reducer

三大原則:

1. 單一數(shù)據(jù)源

  • 整個(gè)應(yīng)用程序的state被存儲(chǔ)在一顆object tree中,并且這個(gè)object tree只存儲(chǔ)在一個(gè) store 中;
  • Redux并沒有強(qiáng)制讓我們不能創(chuàng)建多個(gè)Store截粗,但是那樣做并不利于數(shù)據(jù)的維護(hù)信姓;
  • 單一的數(shù)據(jù)源可以讓整個(gè)應(yīng)用程序的state變得方便維護(hù)、追蹤绸罗、修改意推;
    2.State是只讀的
  • 唯一修改State的方法一定是觸發(fā)action,不要試圖在其他地方通過任何的方式來修改State:
  • 這樣就確保了View或網(wǎng)絡(luò)請(qǐng)求都不能直接修改state珊蟀,它們只能通過action來描述自己想要如何修改state菊值;
  • 這樣可以保證所有的修改都被集中化處理,并且按照嚴(yán)格的順序來執(zhí)行育灸,所以不需要擔(dān)心race condition(竟態(tài))的問題
    3.使用純函數(shù)來執(zhí)行修改
  • 通過reducer將 舊state和 actions聯(lián)系在一起腻窒,并且返回一個(gè)新的State;
  • 隨著應(yīng)用程序的復(fù)雜度增加,我們可以將reducer拆分成多個(gè)小的reducers磅崭,分別操作不同state tree的一部分定页;
  • 但是所有的reducer都應(yīng)該是純函數(shù),不能產(chǎn)生任何的副作用绽诚;
基本用法參考

store/actionCreators.js

import * as actionTypes from "./constants"

export const addNumberAction = (num) => ({
  type: actionTypes.ADD_NUMBER,
  num
})

export const subNumberAction = (num) => ({
  type: actionTypes.SUB_NUMBER,
  num
})

store/constants.js

export const ADD_NUMBER = "add_number"
export const SUB_NUMBER = "sub_number"

store/reducer.js

import * as actionTypes from "./constants"

const initialState = {
  counter: 100
}

function reducer(state = initialState, action) {
  switch (action.type) {
    case actionTypes.ADD_NUMBER:
      return { ...state, counter: state.counter + action.num }
    case actionTypes.SUB_NUMBER:
      return { ...state, counter: state.counter - action.num }
    default:
      return state
  }
}
export default reducer

store/index.js

import { createStore } from "redux"
import reducer from "./reducer"

const store = createStore(reducer)

export default store

以上寫法過期的后續(xù)會(huì)調(diào)整,目前只是基本的思路理解

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市恩够,隨后出現(xiàn)的幾起案子卒落,更是在濱河造成了極大的恐慌,老刑警劉巖蜂桶,帶你破解...
    沈念sama閱讀 206,968評(píng)論 6 482
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件儡毕,死亡現(xiàn)場離奇詭異,居然都是意外死亡扑媚,警方通過查閱死者的電腦和手機(jī)腰湾,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,601評(píng)論 2 382
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來疆股,“玉大人费坊,你說我怎么就攤上這事⊙裕” “怎么了附井?”我有些...
    開封第一講書人閱讀 153,220評(píng)論 0 344
  • 文/不壞的土叔 我叫張陵,是天一觀的道長两残。 經(jīng)常有香客問我永毅,道長,這世上最難降的妖魔是什么人弓? 我笑而不...
    開封第一講書人閱讀 55,416評(píng)論 1 279
  • 正文 為了忘掉前任沼死,我火速辦了婚禮,結(jié)果婚禮上崔赌,老公的妹妹穿的比我還像新娘意蛀。我一直安慰自己,他們只是感情好峰鄙,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,425評(píng)論 5 374
  • 文/花漫 我一把揭開白布浸间。 她就那樣靜靜地躺著,像睡著了一般吟榴。 火紅的嫁衣襯著肌膚如雪魁蒜。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,144評(píng)論 1 285
  • 那天吩翻,我揣著相機(jī)與錄音兜看,去河邊找鬼。 笑死狭瞎,一個(gè)胖子當(dāng)著我的面吹牛细移,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播熊锭,決...
    沈念sama閱讀 38,432評(píng)論 3 401
  • 文/蒼蘭香墨 我猛地睜開眼弧轧,長吁一口氣:“原來是場噩夢啊……” “哼雪侥!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起精绎,我...
    開封第一講書人閱讀 37,088評(píng)論 0 261
  • 序言:老撾萬榮一對(duì)情侶失蹤速缨,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后代乃,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體旬牲,經(jīng)...
    沈念sama閱讀 43,586評(píng)論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,028評(píng)論 2 325
  • 正文 我和宋清朗相戀三年搁吓,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了原茅。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,137評(píng)論 1 334
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡堕仔,死狀恐怖擂橘,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情贮预,我是刑警寧澤贝室,帶...
    沈念sama閱讀 33,783評(píng)論 4 324
  • 正文 年R本政府宣布,位于F島的核電站仿吞,受9級(jí)特大地震影響滑频,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜唤冈,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,343評(píng)論 3 307
  • 文/蒙蒙 一峡迷、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧你虹,春花似錦绘搞、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,333評(píng)論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至董饰,卻和暖如春蒿褂,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背卒暂。 一陣腳步聲響...
    開封第一講書人閱讀 31,559評(píng)論 1 262
  • 我被黑心中介騙來泰國打工啄栓, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人也祠。 一個(gè)月前我還...
    沈念sama閱讀 45,595評(píng)論 2 355
  • 正文 我出身青樓昙楚,卻偏偏與公主長得像,于是被迫代替她去往敵國和親诈嘿。 傳聞我的和親對(duì)象是個(gè)殘疾皇子堪旧,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,901評(píng)論 2 345

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