4.9 KiB
4.9 KiB
id, title, challengeType, isRequired, forumTopicId, localeTitle
id | title | challengeType | isRequired | forumTopicId | localeTitle |
---|---|---|---|---|---|
5a24c314108439a4d4036164 | Create a Component with Composition | 6 | false | 301383 | Создание компонента с композицией |
Description
Navbar
, Dashboard
и Footer
. Чтобы собрать эти компоненты вместе, вы можете создать родительский компонент App
который отображает каждый из этих трех компонентов в качестве дочерних . Чтобы отобразить компонент как дочерний элемент в компоненте React, вы включаете имя компонента, написанное как пользовательский тег HTML в JSX. Например, в методе render
вы можете написать: вернуть (Когда React встречает пользовательский тег HTML, который ссылается на другой компонент (имя компонента, заключенное в
<App>
<Navbar />
<Панель мониторинга />
<Footer />
</ Приложение>
)
< />
как в этом примере), он отображает разметку для этого компонента в местоположении тега. Это должно иллюстрировать отношения между родителями и дочерними элементами между компонентом App
и Navbar
, Dashboard
и Footer
.
Instructions
ChildComponent
и компонент React, называемый ParentComponent
. Составьте два вместе рендерингом ChildComponent
в ParentComponent
. Убедитесь, что тег ChildComponent
косой чертой. Примечание. ChildComponent
определяется с помощью функции стрелок ES6, потому что это очень распространенная практика при использовании React. Однако, знайте, что это всего лишь функция. Если вы не знакомы с синтаксисом функции стрелки, обратитесь к разделу JavaScript.
Tests
tests:
- text: The React component should return a single <code>div</code> element.
testString: assert((function() { var shallowRender = Enzyme.shallow(React.createElement(ParentComponent)); return shallowRender.type() === 'div'; })());
- text: The component should return two nested elements.
testString: assert((function() { var shallowRender = Enzyme.shallow(React.createElement(ParentComponent)); return shallowRender.children().length === 2; })());
- text: The component should return the ChildComponent as its second child.
testString: assert((function() { const mockedComponent = Enzyme.mount(React.createElement(ParentComponent)); return mockedComponent.find('ParentComponent').find('ChildComponent').length === 1; })());
Challenge Seed
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>
);
}
};
After Tests
ReactDOM.render(<ParentComponent />, document.getElementById('root'))
Solution
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 */ }
<ChildComponent />
{ /* change code above this line */ }
</div>
);
}
};