165 lines
5.7 KiB
Markdown
165 lines
5.7 KiB
Markdown
![]() |
---
|
|||
|
id: 5a24c314108439a4d4036169
|
|||
|
title: Передача пропсів простому функціональному компоненту
|
|||
|
challengeType: 6
|
|||
|
forumTopicId: 301402
|
|||
|
dashedName: pass-props-to-a-stateless-functional-component
|
|||
|
---
|
|||
|
|
|||
|
# --description--
|
|||
|
|
|||
|
Попередні завдання охоплювали багато інформації стосовно створення і складання елементів JSX, функціональних компонентів та компонентів класу ES6 в React. Маючи таку базу, саме час перейти до іншої дуже поширеної функції у React: **props**. У React можна передавати пропси або властивості дочірнім компонентам. Припустимо, є компонент `App`, який відображає дочірній компонент з назвою `Welcome`, що є простим функціональним компонентом. Можна передати `Welcome` властивості `user` таким чином:
|
|||
|
|
|||
|
```jsx
|
|||
|
<App>
|
|||
|
<Welcome user='Mark' />
|
|||
|
</App>
|
|||
|
```
|
|||
|
|
|||
|
Використовуйте самостійно створений та який підтримується React **custom HTML attributes** для передачі компоненту. У цьому випадку, створена властивість `user` передається компоненту `Welcome`. Оскільки `Welcome` є простим функціональним компонентом, він має такий доступ до цього значення:
|
|||
|
|
|||
|
```jsx
|
|||
|
const Welcome = (props) => <h1>Hello, {props.user}!</h1>
|
|||
|
```
|
|||
|
|
|||
|
Як правило, це значення називають `props` і при роботі з простими функціональними компонентами, в основному воно розглядається як аргумент функції, яка відображає JSX. Можна отримати доступ до значення аргументу в тілі функції. З компонентами класу, все дещо інакше.
|
|||
|
|
|||
|
# --instructions--
|
|||
|
|
|||
|
У редакторі коду є компоненти `Calendar` та `CurrentDate`. При візуалізації `CurrentDate` з компоненту `Calendar`, передайте зазначену властивість `date` поточній даті об'єкту JavaScript `Date`. Потім перейдіть до `prop` у компоненті `CurrentDate`, демонструючи його значення у межах тегів `p`. Звернуть увагу, що для того, щоб значення `prop` оцінювалися як JavaScript, їх потрібно ставити у фігурні дужки, наприклад, `date={Date()}`.
|
|||
|
|
|||
|
# --hints--
|
|||
|
|
|||
|
Компонент `Calendar` повинен відображати одинарний елемент `div`.
|
|||
|
|
|||
|
```js
|
|||
|
assert(
|
|||
|
(function () {
|
|||
|
const mockedComponent = Enzyme.mount(React.createElement(Calendar));
|
|||
|
return mockedComponent.children().type() === 'div';
|
|||
|
})()
|
|||
|
);
|
|||
|
```
|
|||
|
|
|||
|
Другим дочірнім компонентом `Calendar` має бути компонент `CurrentDate`.
|
|||
|
|
|||
|
```js
|
|||
|
assert(
|
|||
|
(function () {
|
|||
|
const mockedComponent = Enzyme.mount(React.createElement(Calendar));
|
|||
|
return mockedComponent.children().childAt(1).name() === 'CurrentDate';
|
|||
|
})()
|
|||
|
);
|
|||
|
```
|
|||
|
|
|||
|
Компонент `CurrentDate` повинен мати пропс з назвою `date`.
|
|||
|
|
|||
|
```js
|
|||
|
assert(
|
|||
|
(function () {
|
|||
|
const mockedComponent = Enzyme.mount(React.createElement(Calendar));
|
|||
|
return mockedComponent.children().childAt(1).props().date;
|
|||
|
})()
|
|||
|
);
|
|||
|
```
|
|||
|
|
|||
|
Пропс `date` компонента `CurrentDate` повинен містити рядок тексту.
|
|||
|
|
|||
|
```js
|
|||
|
assert(
|
|||
|
(function () {
|
|||
|
const mockedComponent = Enzyme.mount(React.createElement(Calendar));
|
|||
|
const prop = mockedComponent.children().childAt(1).props().date;
|
|||
|
return typeof prop === 'string' && prop.length > 0;
|
|||
|
})()
|
|||
|
);
|
|||
|
```
|
|||
|
|
|||
|
Пропс `date` слід створити за допомогою виклику `Date()`
|
|||
|
|
|||
|
```js
|
|||
|
assert(/<CurrentDatedate={Date\(\)}\/>/.test(__helpers.removeWhiteSpace(code)));
|
|||
|
```
|
|||
|
|
|||
|
Компонент `CurrentDate` повинен відображати значення пропсу `date` у тегу `p`.
|
|||
|
|
|||
|
```js
|
|||
|
let date = 'dummy date';
|
|||
|
assert(
|
|||
|
(function () {
|
|||
|
const mockedComponent = Enzyme.mount(
|
|||
|
React.createElement(CurrentDate, { date })
|
|||
|
);
|
|||
|
return mockedComponent.find('p').html().includes(date);
|
|||
|
})()
|
|||
|
);
|
|||
|
```
|
|||
|
|
|||
|
# --seed--
|
|||
|
|
|||
|
## --after-user-code--
|
|||
|
|
|||
|
```jsx
|
|||
|
ReactDOM.render(<Calendar />, document.getElementById('root'))
|
|||
|
```
|
|||
|
|
|||
|
## --seed-contents--
|
|||
|
|
|||
|
```jsx
|
|||
|
const CurrentDate = (props) => {
|
|||
|
return (
|
|||
|
<div>
|
|||
|
{ /* Change code below this line */ }
|
|||
|
<p>The current date is: </p>
|
|||
|
{ /* Change code above this line */ }
|
|||
|
</div>
|
|||
|
);
|
|||
|
};
|
|||
|
|
|||
|
class Calendar extends React.Component {
|
|||
|
constructor(props) {
|
|||
|
super(props);
|
|||
|
}
|
|||
|
render() {
|
|||
|
return (
|
|||
|
<div>
|
|||
|
<h3>What date is it?</h3>
|
|||
|
{ /* Change code below this line */ }
|
|||
|
<CurrentDate />
|
|||
|
{ /* Change code above this line */ }
|
|||
|
</div>
|
|||
|
);
|
|||
|
}
|
|||
|
};
|
|||
|
```
|
|||
|
|
|||
|
# --solutions--
|
|||
|
|
|||
|
```jsx
|
|||
|
const CurrentDate = (props) => {
|
|||
|
return (
|
|||
|
<div>
|
|||
|
{ /* Change code below this line */ }
|
|||
|
<p>The current date is: {props.date}</p>
|
|||
|
{ /* Change code above this line */ }
|
|||
|
</div>
|
|||
|
);
|
|||
|
};
|
|||
|
|
|||
|
class Calendar extends React.Component {
|
|||
|
constructor(props) {
|
|||
|
super(props);
|
|||
|
}
|
|||
|
render() {
|
|||
|
return (
|
|||
|
<div>
|
|||
|
<h3>What date is it?</h3>
|
|||
|
{ /* Change code below this line */ }
|
|||
|
<CurrentDate date={Date()} />
|
|||
|
{ /* Change code above this line */ }
|
|||
|
</div>
|
|||
|
);
|
|||
|
}
|
|||
|
};
|
|||
|
```
|