The mapDispatchToProps
function lets us inject certain props into the React component that can dispatch actions. For example, the TodoList
component calls its onTodoClick
callback prop with the id
of the todo
.
<Todo
key={todo.id}
{...todo}
onClick={() => onTodoClick(todo.id)}
/>
Inside mapDispatchToProps
in our VisibleTodoList
component we specify that when onTodoClick()
is called with an id
, we want to dispatch the toggleTodo
action with this id
. The toggleTodo
action creator uses this id
to generate an action object that will be dispatched.
const mapDispatchToProps = (dispatch) => ({
onTodoClick(id) {
dispatch(toggleTodo(id));
},
});
const VisibleTodoList = withRouter(connect(
mapStateToProps,
mapDispatchToProps
)(TodoList));
When the arguments for the callback prop match the arguments to the action creator exactly, there is a shorter way to specify mapDispatchToProps
.
Rather than pass a function, we can pass an object mapping of the names of the callback props that we want to inject and the action creator functions that create the corresponding actions.
This is a rather common case, so often you don't need to write mapDispatchToProps
, and you can pass this map in object instead.
const VisibleTodoList = withRouter(connect(
mapStateToProps,
{ onTodoClick: toggleTodo }
)(TodoList));