4.3 KiB
4.3 KiB
id, title, challengeType, isRequired, forumTopicId, localeTitle
id | title | challengeType | isRequired | forumTopicId | localeTitle |
---|---|---|---|---|---|
5a24c314108439a4d4036163 | Create a React Component | 6 | false | 301386 | Создать реактивный компонент |
Description
class
ES6. В следующем примере Kitten
расширяет React.Component
: класс Kitten расширяет React.Component {Это создает класс ES6
конструктор (реквизит) {
супер (реквизит);
}
render () {
вернуть (
<H1> Привет </ h1>
);
}
}
Kitten
, который расширяет React.Component
класс. Таким образом, класс Kitten
теперь имеет доступ ко многим полезным функциям React, таким как локальные состояния и привязки к жизненному циклу. Не беспокойтесь, если вы еще не знакомы с этими условиями, они будут рассмотрены более подробно в последующих задачах. Также обратите внимание, что класс Kitten
имеет constructor
определенный внутри него, который вызывает super()
. Он использует super()
для вызова конструктора родительского класса, в данном случае React.Component
. Конструктор - это специальный метод, используемый при инициализации объектов, созданных с ключевым словом class
. Это лучшая практика для индивидуального вызова компонента constructor
с super
, и передать props
для обоих. Это гарантирует правильность инициализации компонента. Пока что знайте, что это стандарт для включения этого кода. Вскоре вы увидите другие варианты использования конструктора, а также props
.
Instructions
MyComponent
определен в редакторе кода с использованием синтаксиса класса. Завершите запись метода render
чтобы он возвращал элемент div
, содержащий h1
с текстом Hello React!
,
Tests
tests:
- text: The React component should return a <code>div</code> element.
testString: assert(Enzyme.shallow(React.createElement(MyComponent)).type() === 'div');
- text: The returned <code>div</code> should render an <code>h1</code> header within it.
testString: assert(/<div><h1>.*<\/h1><\/div>/.test(Enzyme.shallow(React.createElement(MyComponent)).html()));
- text: The <code>h1</code> header should contain the string <code>Hello React!</code>.
testString: assert(Enzyme.shallow(React.createElement(MyComponent)).html() === '<div><h1>Hello React!</h1></div>');
Challenge Seed
class MyComponent extends React.Component {
constructor(props) {
super(props);
}
render() {
// change code below this line
// change code above this line
}
};
After Tests
ReactDOM.render(<MyComponent />, document.getElementById('root'))
Solution
class MyComponent extends React.Component {
constructor(props) {
super(props);
}
render() {
// change code below this line
return (
<div>
<h1>Hello React!</h1>
</div>
);
// change code above this line
}
};