86 lines
4.8 KiB
Markdown
86 lines
4.8 KiB
Markdown
|
---
|
|||
|
id: 5a24c314108439a4d4036164
|
|||
|
title: Create a Component with Composition
|
|||
|
challengeType: 6
|
|||
|
isRequired: false
|
|||
|
videoUrl: ''
|
|||
|
localeTitle: Создание компонента с композицией
|
|||
|
---
|
|||
|
|
|||
|
## Description
|
|||
|
<section id="description"> Теперь мы рассмотрим, как мы можем собрать несколько компонентов React вместе. Представьте, что вы создаете приложение и создали три компонента: <code>Navbar</code> , <code>Dashboard</code> и <code>Footer</code> . Чтобы собрать эти компоненты вместе, вы можете создать <i>родительский</i> компонент <code>App</code> который отображает каждый из этих трех компонентов в качестве <i>дочерних</i> . Чтобы отобразить компонент как дочерний элемент в компоненте React, вы включаете имя компонента, написанное как пользовательский тег HTML в JSX. Например, в методе <code>render</code> вы можете написать: <blockquote> вернуть ( <br> <App> <br> <Navbar /> <br> <Панель мониторинга /> <br> <Footer /> <br> </ Приложение> <br> ) </blockquote> Когда React встречает пользовательский тег HTML, который ссылается на другой компонент (имя компонента, заключенное в <code>< /></code> как в этом примере), он отображает разметку для этого компонента в местоположении тега. Это должно иллюстрировать отношения между родителями и дочерними элементами между компонентом <code>App</code> и <code>Navbar</code> , <code>Dashboard</code> и <code>Footer</code> . </section>
|
|||
|
|
|||
|
## Instructions
|
|||
|
<section id="instructions"> В редакторе кода есть простой функциональный компонент <code>ChildComponent</code> и компонент React, называемый <code>ParentComponent</code> . Составьте два вместе рендерингом <code>ChildComponent</code> в <code>ParentComponent</code> . Убедитесь, что тег <code>ChildComponent</code> косой чертой. <strong>Примечание.</strong> <code>ChildComponent</code> определяется с помощью функции стрелок ES6, потому что это очень распространенная практика при использовании React. Однако, знайте, что это всего лишь функция. Если вы не знакомы с синтаксисом функции стрелки, обратитесь к разделу JavaScript. </section>
|
|||
|
|
|||
|
## Tests
|
|||
|
<section id='tests'>
|
|||
|
|
|||
|
```yml
|
|||
|
tests:
|
|||
|
- text: Компонент React должен возвращать один элемент <code>div</code> .
|
|||
|
testString: 'assert((function() { var shallowRender = Enzyme.shallow(React.createElement(ParentComponent)); return shallowRender.type() === "div"; })(), "The React component should return a single <code>div</code> element.");'
|
|||
|
- text: Компонент должен возвращать два вложенных элемента.
|
|||
|
testString: 'assert((function() { var shallowRender = Enzyme.shallow(React.createElement(ParentComponent)); return shallowRender.children().length === 2; })(), "The component should return two nested elements.");'
|
|||
|
- text: Компонент должен вернуть ChildComponent в качестве второго ребенка.
|
|||
|
testString: 'assert((function() { const mockedComponent = Enzyme.mount(React.createElement(ParentComponent)); return mockedComponent.find("ParentComponent").find("ChildComponent").length === 1; })(), "The component should return the ChildComponent as its second child.");'
|
|||
|
|
|||
|
```
|
|||
|
|
|||
|
</section>
|
|||
|
|
|||
|
## Challenge Seed
|
|||
|
<section id='challengeSeed'>
|
|||
|
|
|||
|
<div id='jsx-seed'>
|
|||
|
|
|||
|
```jsx
|
|||
|
const ChildComponent = () => {
|
|||
|
return (
|
|||
|
<div>
|
|||
|
<p>I am the child</p>
|
|||
|
</div>
|
|||
|
);
|
|||
|
};
|
|||
|
|
|||
|
class ParentComponent extends React.Component {
|
|||
|
constructor(props) {
|
|||
|
super(props);
|
|||
|
}
|
|||
|
render() {
|
|||
|
return (
|
|||
|
<div>
|
|||
|
<h1>I am the parent</h1>
|
|||
|
{ /* change code below this line */ }
|
|||
|
|
|||
|
|
|||
|
{ /* change code above this line */ }
|
|||
|
</div>
|
|||
|
);
|
|||
|
}
|
|||
|
};
|
|||
|
|
|||
|
```
|
|||
|
|
|||
|
</div>
|
|||
|
|
|||
|
|
|||
|
### After Test
|
|||
|
<div id='jsx-teardown'>
|
|||
|
|
|||
|
```js
|
|||
|
console.info('after the test');
|
|||
|
```
|
|||
|
|
|||
|
</div>
|
|||
|
|
|||
|
</section>
|
|||
|
|
|||
|
## Solution
|
|||
|
<section id='solution'>
|
|||
|
|
|||
|
```js
|
|||
|
// solution required
|
|||
|
```
|
|||
|
</section>
|