freeCodeCamp/curriculum/challenges/russian/03-front-end-libraries/react/create-a-component-with-com...

4.8 KiB
Raw Blame History

id title challengeType isRequired videoUrl localeTitle
5a24c314108439a4d4036164 Create a Component with Composition 6 false Создание компонента с композицией

Description

Теперь мы рассмотрим, как мы можем собрать несколько компонентов React вместе. Представьте, что вы создаете приложение и создали три компонента: Navbar , Dashboard и Footer . Чтобы собрать эти компоненты вместе, вы можете создать родительский компонент App который отображает каждый из этих трех компонентов в качестве дочерних . Чтобы отобразить компонент как дочерний элемент в компоненте React, вы включаете имя компонента, написанное как пользовательский тег HTML в JSX. Например, в методе render вы можете написать:
вернуть (
<App>
<Navbar />
<Панель мониторинга />
<Footer />
</ Приложение>
)
Когда React встречает пользовательский тег HTML, который ссылается на другой компонент (имя компонента, заключенное в < /> как в этом примере), он отображает разметку для этого компонента в местоположении тега. Это должно иллюстрировать отношения между родителями и дочерними элементами между компонентом App и Navbar , Dashboard и Footer .

Instructions

В редакторе кода есть простой функциональный компонент ChildComponent и компонент React, называемый ParentComponent . Составьте два вместе рендерингом ChildComponent в ParentComponent . Убедитесь, что тег ChildComponent косой чертой. Примечание. ChildComponent определяется с помощью функции стрелок ES6, потому что это очень распространенная практика при использовании React. Однако, знайте, что это всего лишь функция. Если вы не знакомы с синтаксисом функции стрелки, обратитесь к разделу JavaScript.

Tests

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.");'

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 Test

console.info('after the test');

Solution

// solution required