react-redux基本使用思考

Time: 2019-08-18

Provider組件與connect方法

import React from "react";
import ReactDOM from "react-dom";

import { Provider } from "react-redux";
import store from "./store";

import App from "./App";

const rootElement = document.getElementById("root");
ReactDOM.render(
  <Provider store={store}>
    <App />
  </Provider>,
  rootElement
);

Provider組件使得應(yīng)用可在全局訪問store余爆。

connect方法

將組件與store聯(lián)系起來,不用setState觸發(fā)組件更新宝踪。

Action

action是把數(shù)據(jù)從應(yīng)用傳到store有效載荷。是store數(shù)據(jù)的唯一來源赞季。

一般傳遞action的方式:

store.dispatch()

action用于描述發(fā)生了什么租谈,使用reducers來按照action更新state,store是聯(lián)系三者的對象商叹。

Store

職責(zé):

根據(jù)已有的reducer創(chuàng)建store请唱。

通過combineReducers()將多個reducer合并為一個總的弥咪,然后用createStore(rootReducer)創(chuàng)建store过蹂。

createStore可以接收第二個參數(shù),用于設(shè)置state的初始狀態(tài)聚至。

需要區(qū)分storestate和組件的狀態(tài)酷勺。

Redux生命周期

  • store.dispatch(action)

可以在任何地方調(diào)用 store.dispatch(action),包括組件中扳躬、XHR 回調(diào)中脆诉、甚至定時器中。

  • store調(diào)用傳入的reducer函數(shù)坦报,reducer函數(shù)接收兩個參數(shù),當(dāng)前狀態(tài)和action狂鞋。

reducer是純函數(shù)片择。

  • reducer會合并多個子reducer的輸出結(jié)果,形成單一的狀態(tài)樹骚揍,這個就是應(yīng)用的下一個state字管。
  • store.subscribe(listener),所有訂閱的監(jiān)聽器都會觸發(fā)信不,獲取當(dāng)前狀態(tài):store.getState()

此時只是store的狀態(tài)嘲叔,為了更新UI,用store的狀態(tài)數(shù)據(jù)來更新組件狀態(tài)抽活。

如果你使用了 React Redux 這類的綁定庫硫戈,這時就應(yīng)該調(diào)用 component.setState(newState) 來更新。

展示組件 容器組件
作用 描述如何展現(xiàn)(骨架下硕、樣式) 描述如何運行(數(shù)據(jù)獲取丁逝、狀態(tài)更新)
直接使用 Redux
數(shù)據(jù)來源 props 監(jiān)聽 Redux state
數(shù)據(jù)修改 從 props 調(diào)用回調(diào)函數(shù) 向 Redux 派發(fā) actions
調(diào)用方式 手動 通常由 React Redux 生成

容器組件

技術(shù)上講,容器組件就是使用 store.subscribe() 從 Redux state 樹中讀取部分?jǐn)?shù)據(jù)梭姓,并通過 props 來把這些數(shù)據(jù)提供給要渲染的組件霜幼。

可以手工來開發(fā)容器組件,但建議使用 React Redux 庫的 connect() 方法來生成誉尖。

容器組件關(guān)注的是將表現(xiàn)層連接到數(shù)據(jù)罪既。

表現(xiàn)層組件通過props獲取數(shù)據(jù)。

當(dāng)用戶想將某個表現(xiàn)組件和數(shù)據(jù)相連時铡恕,可以將組件包裹到容器中琢感。

Q: 容器中的數(shù)據(jù)如何獲取探熔?從store狀態(tài)映射到組件猩谊,store是全局,通過上下文獲取祭刚。

使用connect

使用 connect() 前牌捷,需要先定義 mapStateToProps 這個函數(shù)來指定如何把當(dāng)前 Redux store state 映射到展示組件的 props 中墙牌。

容器組件的職責(zé):

  • 讀取state
  • 分發(fā)action

定義 mapDispatchToProps() 方法接收 dispatch() 方法并返回期望注入到展示組件的 props 中的回調(diào)方法。

const getVisibleTodos = (todos, filter) => {
  switch (filter) {
    case 'SHOW_COMPLETED':
      return todos.filter(t => t.completed)
    case 'SHOW_ACTIVE':
      return todos.filter(t => !t.completed)
    case 'SHOW_ALL':
    default:
      return todos
  }
}

const mapStateToProps = state => {
  return {
    todos: getVisibleTodos(state.todos, state.visibilityFilter)
  }
}

const mapDispatchToProps = dispatch => {
  return {
    onTodoClick: id => {
      dispatch(toggleTodo(id))
    }
  }
}

這里的mapStateToPropsmapDispatchToProps名稱可以自定義暗甥。

最后喜滨,使用 connect() 創(chuàng)建 VisibleTodoList,并傳入這兩個函數(shù)撤防。

import { connect } from 'react-redux'

const VisibleTodoList = connect(
  mapStateToProps,
  mapDispatchToProps
)(TodoList)

export default VisibleTodoList

從以下幾個地方設(shè)定:

  • 展示組件
  • 容器組件
  • reducers
  • actions

初始狀態(tài)寫在reducers中虽风,reducers會接收初始狀態(tài),并分發(fā)action寄月。

容器組件會為組件綁定數(shù)據(jù)和回調(diào)函數(shù)辜膝,回調(diào)函數(shù)可以在組件的任何地方通過props.xx調(diào)用。

為什么傳遞函數(shù)給組件

使用store時漾肮,我們假定組件的狀態(tài)全交給redux來管理了厂抖。那么,修改store會觸發(fā)UI的重新渲染克懊。所以容器組件需要將能夠修改store的函數(shù)傳遞到組件忱辅,讓組件在合適的情況下調(diào)用。

改變store的唯一方式是分發(fā)行為谭溉,所以mapDispatchToProps就是干這件事情:將分發(fā)行為的函數(shù)作為props傳遞給組件墙懂。

參考

http://cn.redux.js.org/

http://cn.redux.js.org/docs/basics/UsageWithReact.html

reduxPPT,非常好

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末扮念,一起剝皮案震驚了整個濱河市损搬,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌柜与,老刑警劉巖场躯,帶你破解...
    沈念sama閱讀 219,188評論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異旅挤,居然都是意外死亡踢关,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,464評論 3 395
  • 文/潘曉璐 我一進(jìn)店門粘茄,熙熙樓的掌柜王于貴愁眉苦臉地迎上來签舞,“玉大人,你說我怎么就攤上這事柒瓣∪宕睿” “怎么了?”我有些...
    開封第一講書人閱讀 165,562評論 0 356
  • 文/不壞的土叔 我叫張陵芙贫,是天一觀的道長搂鲫。 經(jīng)常有香客問我,道長磺平,這世上最難降的妖魔是什么魂仍? 我笑而不...
    開封第一講書人閱讀 58,893評論 1 295
  • 正文 為了忘掉前任拐辽,我火速辦了婚禮,結(jié)果婚禮上擦酌,老公的妹妹穿的比我還像新娘俱诸。我一直安慰自己,他們只是感情好赊舶,可當(dāng)我...
    茶點故事閱讀 67,917評論 6 392
  • 文/花漫 我一把揭開白布睁搭。 她就那樣靜靜地躺著,像睡著了一般笼平。 火紅的嫁衣襯著肌膚如雪园骆。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,708評論 1 305
  • 那天寓调,我揣著相機(jī)與錄音锌唾,去河邊找鬼。 笑死捶牢,一個胖子當(dāng)著我的面吹牛鸠珠,可吹牛的內(nèi)容都是我干的巍耗。 我是一名探鬼主播秋麸,決...
    沈念sama閱讀 40,430評論 3 420
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼炬太!你這毒婦竟也來了灸蟆?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,342評論 0 276
  • 序言:老撾萬榮一對情侶失蹤亲族,失蹤者是張志新(化名)和其女友劉穎炒考,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體霎迫,經(jīng)...
    沈念sama閱讀 45,801評論 1 317
  • 正文 獨居荒郊野嶺守林人離奇死亡斋枢,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,976評論 3 337
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了知给。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片瓤帚。...
    茶點故事閱讀 40,115評論 1 351
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖涩赢,靈堂內(nèi)的尸體忽然破棺而出戈次,到底是詐尸還是另有隱情,我是刑警寧澤筒扒,帶...
    沈念sama閱讀 35,804評論 5 346
  • 正文 年R本政府宣布怯邪,位于F島的核電站,受9級特大地震影響花墩,放射性物質(zhì)發(fā)生泄漏悬秉。R本人自食惡果不足惜澄步,卻給世界環(huán)境...
    茶點故事閱讀 41,458評論 3 331
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望搂捧。 院中可真熱鬧驮俗,春花似錦、人聲如沸允跑。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,008評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽聋丝。三九已至索烹,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間弱睦,已是汗流浹背百姓。 一陣腳步聲響...
    開封第一講書人閱讀 33,135評論 1 272
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點兒被人妖公主榨干…… 1. 我叫王不留况木,地道東北人垒拢。 一個月前我還...
    沈念sama閱讀 48,365評論 3 373
  • 正文 我出身青樓,卻偏偏與公主長得像火惊,于是被迫代替她去往敵國和親求类。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 45,055評論 2 355

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