74 lines
3.3 KiB
Markdown
74 lines
3.3 KiB
Markdown
---
|
|
id: 5a24c314108439a4d4036163
|
|
title: Create a React Component
|
|
challengeType: 6
|
|
isRequired: false
|
|
videoUrl: ''
|
|
localeTitle: Crear un componente React
|
|
---
|
|
|
|
## Description
|
|
<section id="description"> La otra forma de definir un componente React es con la sintaxis de <code>class</code> ES6. En el siguiente ejemplo, <code>Kitten</code> extiende <code>React.Component</code> : <blockquote> clase gatito extiende React.Component { <br> constructor (accesorios) { <br> super (accesorios); <br> } <br><br> render () { <br> regreso ( <br> <h1> Hola </h1> <br> ); <br> } <br> } </blockquote> Esto crea un <code>Kitten</code> clase ES6 que extiende la clase <code>React.Component</code> . Por lo tanto, la clase <code>Kitten</code> ahora tiene acceso a muchas características útiles de React, como los enlaces locales de estado y ciclo de vida. No se preocupe si aún no está familiarizado con estos términos, se cubrirán con mayor detalle en los desafíos posteriores. También tenga en cuenta que la clase <code>Kitten</code> tiene un <code>constructor</code> definido dentro de él que llama a <code>super()</code> . Utiliza <code>super()</code> para llamar al constructor de la clase padre, en este caso <code>React.Component</code> . El constructor es un método especial utilizado durante la inicialización de objetos que se crean con la palabra clave de <code>class</code> . Es una práctica recomendada llamar al <code>constructor</code> un componente con <code>super</code> y pasarle <code>props</code> a ambos. Esto asegura que el componente se inicialice correctamente. Por ahora, sepa que es estándar que se incluya este código. Pronto verás otros usos para el constructor, así como <code>props</code> . </section>
|
|
|
|
## Instructions
|
|
<section id="instructions"> <code>MyComponent</code> se define en el editor de código usando la sintaxis de clase. Termine de escribir el método de <code>render</code> para que devuelva un elemento <code>div</code> que contenga un <code>h1</code> con el texto <code>Hello React!</code> . </section>
|
|
|
|
## Tests
|
|
<section id='tests'>
|
|
|
|
```yml
|
|
tests:
|
|
- text: El componente React debe devolver un elemento <code>div</code> .
|
|
testString: 'assert(Enzyme.shallow(React.createElement(MyComponent)).type() === "div", "The React component should return a <code>div</code> element.");'
|
|
- text: El <code>div</code> devuelto debe representar un encabezado <code>h1</code> dentro de él.
|
|
testString: 'assert(/<div><h1>.*<\/h1><\/div>/.test(Enzyme.shallow(React.createElement(MyComponent)).html()), "The returned <code>div</code> should render an <code>h1</code> header within it.");'
|
|
- text: El encabezado <code>h1</code> debe contener la cadena <code>Hello React!</code> .
|
|
testString: 'assert(Enzyme.shallow(React.createElement(MyComponent)).html() === "<div><h1>Hello React!</h1></div>", "The <code>h1</code> header should contain the string <code>Hello React!</code>.");'
|
|
|
|
```
|
|
|
|
</section>
|
|
|
|
## Challenge Seed
|
|
<section id='challengeSeed'>
|
|
|
|
<div id='jsx-seed'>
|
|
|
|
```jsx
|
|
class MyComponent extends React.Component {
|
|
constructor(props) {
|
|
super(props);
|
|
}
|
|
render() {
|
|
// change code below this line
|
|
|
|
|
|
|
|
// change code above this line
|
|
}
|
|
};
|
|
|
|
```
|
|
|
|
</div>
|
|
|
|
|
|
### After Test
|
|
<div id='jsx-teardown'>
|
|
|
|
```js
|
|
console.info('after the test');
|
|
```
|
|
|
|
</div>
|
|
|
|
</section>
|
|
|
|
## Solution
|
|
<section id='solution'>
|
|
|
|
```js
|
|
// solution required
|
|
```
|
|
</section>
|