5.7 KiB
id | title | challengeType | forumTopicId | dashedName |
---|---|---|---|---|
5a24c314108439a4d4036169 | Передача пропсів простому функціональному компоненту | 6 | 301402 | pass-props-to-a-stateless-functional-component |
--description--
Попередні завдання охоплювали багато інформації стосовно створення і складання елементів JSX, функціональних компонентів та компонентів класу ES6 в React. Маючи таку базу, саме час перейти до іншої дуже поширеної функції у React: props. У React можна передавати пропси або властивості дочірнім компонентам. Припустимо, є компонент App
, який відображає дочірній компонент з назвою Welcome
, що є простим функціональним компонентом. Можна передати Welcome
властивості user
таким чином:
<App>
<Welcome user='Mark' />
</App>
Використовуйте самостійно створений та який підтримується React custom HTML attributes для передачі компоненту. У цьому випадку, створена властивість user
передається компоненту Welcome
. Оскільки Welcome
є простим функціональним компонентом, він має такий доступ до цього значення:
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
.
assert(
(function () {
const mockedComponent = Enzyme.mount(React.createElement(Calendar));
return mockedComponent.children().type() === 'div';
})()
);
Другим дочірнім компонентом Calendar
має бути компонент CurrentDate
.
assert(
(function () {
const mockedComponent = Enzyme.mount(React.createElement(Calendar));
return mockedComponent.children().childAt(1).name() === 'CurrentDate';
})()
);
Компонент CurrentDate
повинен мати пропс з назвою date
.
assert(
(function () {
const mockedComponent = Enzyme.mount(React.createElement(Calendar));
return mockedComponent.children().childAt(1).props().date;
})()
);
Пропс date
компонента CurrentDate
повинен містити рядок тексту.
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()
assert(/<CurrentDatedate={Date\(\)}\/>/.test(__helpers.removeWhiteSpace(code)));
Компонент CurrentDate
повинен відображати значення пропсу date
у тегу p
.
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--
ReactDOM.render(<Calendar />, document.getElementById('root'))
--seed-contents--
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--
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>
);
}
};