freeCodeCamp/curriculum/challenges/spanish/03-front-end-libraries/react/create-a-react-component.sp...

74 lines
3.3 KiB
Markdown
Raw Normal View History

2018-10-08 17:34:43 +00:00
---
id: 5a24c314108439a4d4036163
title: Create a React Component
challengeType: 6
isRequired: false
2018-10-10 20:20:40 +00:00
videoUrl: ''
localeTitle: Crear un componente React
2018-10-08 17:34:43 +00:00
---
## Description
2018-10-10 20:20:40 +00:00
<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> &lt;h1&gt; Hola &lt;/h1&gt; <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>
2018-10-08 17:34:43 +00:00
## Instructions
2018-10-10 20:20:40 +00:00
<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>
2018-10-08 17:34:43 +00:00
## 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
}
};
2018-10-10 20:20:40 +00:00
2018-10-08 17:34:43 +00:00
```
</div>
### After Test
<div id='jsx-teardown'>
```js
console.info('after the test');
```
</div>
</section>
## Solution
<section id='solution'>
```js
2018-10-10 20:20:40 +00:00
// solution required
2018-10-08 17:34:43 +00:00
```
</section>