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));
|
|||
|
}
|
|||
|
}
|
|||
|
};
|
|||
|
```
|