108 lines
4.2 KiB
Markdown
108 lines
4.2 KiB
Markdown
---
|
||
id: 5a24c314108439a4d4036146
|
||
title: Перетворіть дані Dispatch в Props
|
||
challengeType: 6
|
||
forumTopicId: 301432
|
||
dashedName: map-dispatch-to-props
|
||
---
|
||
|
||
# --description--
|
||
|
||
Функція `mapDispatchToProps()` використовується для забезпечення певних авторів дій для ваших компонентів React, щоб вони могли відправляти дії за рахунок сховища Redux. Вона схожа по структурі на функцію `mapStateToProps()`, яку ви написали в останньому завданні. Вона повертає об'єкт, який зіставляє дії відправлення з назвами параметрів, які стають компонентами `props`. Тим не менш, замість того, щоб повертати частину `state`, кожен параметр повертає функцію, що викликає `dispatch` з творцем дії та будь-якими відповідними данними дії. Ви маєте доступ до `dispatch`, тому що він передається в `mapDispatchToProps()` як параметр, коли ви визначаєте функцію, так само, як ви пройшли від `state` до `mapStateToProps()`. По секрету, React Redux використовує Redux `store.dispatch()` для проведення цих відправлень за допомогою `mapDispatchToProps()`. Це схоже на те, як він використовує `store.subscribe()` для компонентів, зіставлених на `state`.
|
||
|
||
Наприклад, у вас є творець дій `loginUser()`, який приймає `username`, як корисну дію. Об'єкт, повернений з `mapDispatchToProps()` для цього творця дій виглядатиме приблизно так:
|
||
|
||
```jsx
|
||
{
|
||
submitLoginUser: function(username) {
|
||
dispatch(loginUser(username));
|
||
}
|
||
}
|
||
```
|
||
|
||
# --instructions--
|
||
|
||
Редактор коду надає творця дії, який називається `addMessage()`. Запишіть функцію `mapDispatchToProps()`, яка приймає `dispatch` як аргумент, а потім повертає об'єкт. Об'єкт повинен мати встановлену власність `submitNewMessage` на функцію відправлення, яка приймає параметр додавання для нового повідомлення, щоб надіслати `addMessage()`.
|
||
|
||
# --hints--
|
||
|
||
`addMessage` повинен повертати об'єкт за допомогою ключів `type` та `message`.
|
||
|
||
```js
|
||
assert(
|
||
(function () {
|
||
const addMessageTest = addMessage();
|
||
return (
|
||
addMessageTest.hasOwnProperty('type') &&
|
||
addMessageTest.hasOwnProperty('message')
|
||
);
|
||
})()
|
||
);
|
||
```
|
||
|
||
`mapDispatchToProps` повинна бути функцією.
|
||
|
||
```js
|
||
assert(typeof mapDispatchToProps === 'function');
|
||
```
|
||
|
||
`mapDispatchToProps` повинен повертати об'єкт.
|
||
|
||
```js
|
||
assert(typeof mapDispatchToProps() === 'object');
|
||
```
|
||
|
||
Надсилання `addMessage` разом з `submitNewMessage` від `mapDispatchToProps` повинне повернути повідомлення до функції відправлення.
|
||
|
||
```js
|
||
assert(
|
||
(function () {
|
||
let testAction;
|
||
const dispatch = (fn) => {
|
||
testAction = fn;
|
||
};
|
||
let dispatchFn = mapDispatchToProps(dispatch);
|
||
dispatchFn.submitNewMessage('__TEST__MESSAGE__');
|
||
return (
|
||
testAction.type === 'ADD' && testAction.message === '__TEST__MESSAGE__'
|
||
);
|
||
})()
|
||
);
|
||
```
|
||
|
||
# --seed--
|
||
|
||
## --seed-contents--
|
||
|
||
```jsx
|
||
const addMessage = (message) => {
|
||
return {
|
||
type: 'ADD',
|
||
message: message
|
||
}
|
||
};
|
||
|
||
// Change code below this line
|
||
```
|
||
|
||
# --solutions--
|
||
|
||
```jsx
|
||
const addMessage = (message) => {
|
||
return {
|
||
type: 'ADD',
|
||
message: message
|
||
}
|
||
};
|
||
|
||
// Change code below this line
|
||
|
||
const mapDispatchToProps = (dispatch) => {
|
||
return {
|
||
submitNewMessage: function(message) {
|
||
dispatch(addMessage(message));
|
||
}
|
||
}
|
||
};
|
||
```
|