Redux框架之bindActionCreators()用法講解

bindActionCreators

  • bindActionCreators(actionCreators, dispatch)

  • 把 action creators 轉(zhuǎn)成擁有同名 keys 的對(duì)象票渠,但使用 dispatch 把每個(gè) action creator 包圍起來(lái),這樣可以直接調(diào)用它們昂秃。

  • 一般情況下你可以直接在 Store 實(shí)例上調(diào)用 dispatch杜窄。如果你在 React 中使用 Redux,react-redux 會(huì)提供 dispatch 塞耕。

  • 惟一使用 bindActionCreators 的場(chǎng)景是當(dāng)你需要把 action creator 往下傳到一個(gè)組件上扫外,卻不想讓這個(gè)組件覺(jué)察到 Redux 的存在,而且不希望把 Redux store 或 dispatch 傳給它筛谚。

  • 為方便起見(jiàn),你可以傳入一個(gè)函數(shù)作為第一個(gè)參數(shù)蚊伞,它會(huì)返回一個(gè)函數(shù)吮铭。

參數(shù)

  • actionCreators (Function or Object): 一個(gè) action creator,或者鍵值是 action creators 的對(duì)象别垮。

  • dispatch (Function): 一個(gè) dispatch 函數(shù)扎谎,由 Store 實(shí)例提供。

返回值

  • (Function or Object): 一個(gè)與原對(duì)象類似的對(duì)象胧奔,只不過(guò)這個(gè)對(duì)象中的的每個(gè)函數(shù)值都可以直接 dispatch action预吆。如果傳入的是一個(gè)函數(shù),返回的也是一個(gè)函數(shù)。

示例

TodoActionCreators.js

export function addTodo(text) {
  return {
    type: 'ADD_TODO',
    text
  };
}

export function removeTodo(id) {
  return {
    type: 'REMOVE_TODO',
    id
  };
}
  • SomeComponent.js*
import { Component } from 'react';
import { bindActionCreators } from 'redux';
import { connect } from 'react-redux';

import * as TodoActionCreators from './TodoActionCreators';
console.log(TodoActionCreators);
// {
//   addTodo: Function,
//   removeTodo: Function
// }

class TodoListContainer extends Component {
  componentDidMount() {
    // 由 react-redux 注入:
    let { dispatch } = this.props;

    // 注意:這樣做行不通:
    // TodoActionCreators.addTodo('Use Redux');

    // 你只是調(diào)用了創(chuàng)建 action 的方法。
    // 你必須要 dispatch action 而已宿礁。

    // 這樣做行得通:
    let action = TodoActionCreators.addTodo('Use Redux');
    dispatch(action);
  }

  render() {
    // 由 react-redux 注入:
    let { todos, dispatch } = this.props;

    // 這是應(yīng)用 bindActionCreators 比較好的場(chǎng)景:
    // 在子組件里,可以完全不知道 Redux 的存在控汉。

    let boundActionCreators = bindActionCreators(TodoActionCreators, dispatch);
    console.log(boundActionCreators);
    // {
    //   addTodo: Function,
    //   removeTodo: Function
    // }

    return (
      <TodoList todos={todos}
                {...boundActionCreators} />
    );

    // 一種可以替換 bindActionCreators 的做法是直接把 dispatch 函數(shù)
    // 和 action creators 當(dāng)作 props 
    // 傳遞給子組件
    // return <TodoList todos={todos} dispatch={dispatch} />;
  }
}

export default connect(
  state => ({ todos: state.todos })
)(TodoListContainer)

你或許要問(wèn):為什么不直接把 action creators 綁定到 store 實(shí)例上返吻,就像傳統(tǒng) Flux 那樣测僵?問(wèn)題是這樣做的話如果開(kāi)發(fā)同構(gòu)應(yīng)用,在服務(wù)端渲染時(shí)就不行了捍靠。多數(shù)情況下,你 每個(gè)請(qǐng)求都需要一個(gè)獨(dú)立的 store 實(shí)例,這樣你可以為它們提供不同的數(shù)據(jù)吊宋,但是在定義的時(shí)候綁定 action creators璃搜,你就可以使用一個(gè)唯一的 store 實(shí)例來(lái)對(duì)應(yīng)所有請(qǐng)求了。

如果你使用 ES5这吻,不能使用 import * as 語(yǔ)法,你可以把 require('./TodoActionCreators') 作為第一個(gè)參數(shù)傳給 bindActionCreators怠硼。惟一要考慮的是 actionCreators 的參數(shù)全是函數(shù)移怯。模塊加載系統(tǒng)并不重要。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末葡秒,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子蹋岩,更是在濱河造成了極大的恐慌学少,老刑警劉巖,帶你破解...
    沈念sama閱讀 217,509評(píng)論 6 504
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件禁偎,死亡現(xiàn)場(chǎng)離奇詭異阀坏,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)盒至,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,806評(píng)論 3 394
  • 文/潘曉璐 我一進(jìn)店門(mén)士修,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人酒唉,你說(shuō)我怎么就攤上這事沸移。” “怎么了雹锣?”我有些...
    開(kāi)封第一講書(shū)人閱讀 163,875評(píng)論 0 354
  • 文/不壞的土叔 我叫張陵蕊爵,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我醋旦,道長(zhǎng)会放,這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,441評(píng)論 1 293
  • 正文 為了忘掉前任箩张,我火速辦了婚禮,結(jié)果婚禮上饮笛,老公的妹妹穿的比我還像新娘论熙。我一直安慰自己,他們只是感情好脓诡,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,488評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布祝谚。 她就那樣靜靜地躺著恳不,像睡著了一般变秦。 火紅的嫁衣襯著肌膚如雪席爽。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書(shū)人閱讀 51,365評(píng)論 1 302
  • 那天玖像,我揣著相機(jī)與錄音齐饮,去河邊找鬼。 笑死沈矿,一個(gè)胖子當(dāng)著我的面吹牛咬腋,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播陵像,決...
    沈念sama閱讀 40,190評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼寇壳,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了泞歉?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書(shū)人閱讀 39,062評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤榛丢,失蹤者是張志新(化名)和其女友劉穎挺庞,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體掖鱼,經(jīng)...
    沈念sama閱讀 45,500評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡戏挡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,706評(píng)論 3 335
  • 正文 我和宋清朗相戀三年隘谣,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片掌栅。...
    茶點(diǎn)故事閱讀 39,834評(píng)論 1 347
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡码泛,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出晌缘,到底是詐尸還是另有隱情痢站,我是刑警寧澤,帶...
    沈念sama閱讀 35,559評(píng)論 5 345
  • 正文 年R本政府宣布岳枷,位于F島的核電站呜叫,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏盛泡。R本人自食惡果不足惜娱颊,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,167評(píng)論 3 328
  • 文/蒙蒙 一凯砍、第九天 我趴在偏房一處隱蔽的房頂上張望掰吕。 院中可真熱鬧,春花似錦殖熟、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,779評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至饼齿,卻和暖如春蝙搔,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背吃型。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 32,912評(píng)論 1 269
  • 我被黑心中介騙來(lái)泰國(guó)打工勤晚, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人赐写。 一個(gè)月前我還...
    沈念sama閱讀 47,958評(píng)論 2 370
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像挺邀,于是被迫代替她去往敵國(guó)和親揉忘。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,779評(píng)論 2 354

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

  • Redux的三大原則 Redux 可以用這三個(gè)基本原則來(lái)描述: 單一數(shù)據(jù)源 整個(gè)應(yīng)用的 state被儲(chǔ)存在一棵 o...
    Dabao123閱讀 678評(píng)論 0 2
  • 前言 本文 有配套視頻悠夯,可以酌情觀看。 文中內(nèi)容因各人理解不同躺坟,可能會(huì)有所偏差沦补,歡迎朋友們聯(lián)系我討論。 文中所有內(nèi)...
    珍此良辰閱讀 11,906評(píng)論 23 111
  • react-redux 在react-redux 框架中咪橙,給我提供了兩個(gè)常用的API來(lái)配合Redux框架的使用夕膀,其...
    光強(qiáng)_上海閱讀 35,376評(píng)論 5 54
  • 寫(xiě)在開(kāi)頭 本片內(nèi)容主要為本人在閱讀redux官方文檔中基礎(chǔ)和進(jìn)階部分的學(xué)習(xí)筆記虚倒。由于本人能力有限,所以文章中可能會(huì)...
    前端開(kāi)發(fā)愛(ài)好者閱讀 1,194評(píng)論 0 4
  • Redux簡(jiǎn)介 Redux從設(shè)計(jì)之初就不是為了編寫(xiě)最短产舞、最快的代碼,他是為了解決 “當(dāng)有確定的狀態(tài)發(fā)生改變時(shí)易猫,數(shù)據(jù)...
    _花閱讀 410評(píng)論 0 1