freeCodeCamp/curriculum/challenges/portuguese/03-front-end-libraries/react/render-html-elements-to-the...

2.2 KiB

id title challengeType forumTopicId dashedName
5a24bbe0dba28a8d3cbd4c5f Renderizar elementos HTML para o DOM 6 301406 render-html-elements-to-the-dom

--description--

Até agora, você aprendeu que JSX é uma ferramenta conveniente para escrever HTML legível dentro de JavaScript. Com React, podemos renderizar esse JSX diretamente para o DOM HTML usando a API de renderização do React conhecida como ReactDOM.

ReactDOM oferece um método simples para renderizar elementos React para o DOM que se parece com isso: ReactDOM.render(componentToRender, targetNode), onde o primeiro argumento é o elemento ou componente que você deseja renderizar, e o segundo argumento é o nó do DOM onde você deseja renderizar o componente.

Como você esperaria, ReactDOM.render() deve ser chamado após as declarações dos elementos JSX, assim como você deve declarar variáveis antes de usá-las.

--instructions--

O editor de código tem um componente JSX simples. Use o método ReactDOM.render() para renderizar este componente na página. Você pode passar elementos JSX definidos diretamente como o primeiro argumento e usar document.getElementById() para selecionar o nó do DOM onde renderizá-los. Há um div com id='challenge-node' disponível para você usar. Certifique-se de não alterar a constante JSX.

--hints--

A constante JSX deve retornar um elemento div.

assert(JSX.type === 'div');

O div deve conter uma tag h1 como o primeiro elemento.

assert(JSX.props.children[0].type === 'h1');

O div deve conter uma tag p como segundo elemento.

assert(JSX.props.children[1].type === 'p');

O elemento JSX fornecido deve renderizar ao nó do DOM com id challenge-node.

assert(
  document.getElementById('challenge-node').childNodes[0].innerHTML ===
    '<h1>Hello World</h1><p>Lets render this to the DOM</p>'
);

--seed--

--seed-contents--

const JSX = (
  <div>
    <h1>Hello World</h1>
    <p>Lets render this to the DOM</p>
  </div>
);
// Change code below this line

--solutions--

const JSX = (
<div>
  <h1>Hello World</h1>
  <p>Lets render this to the DOM</p>
</div>
);
// Change code below this line
ReactDOM.render(JSX, document.getElementById('challenge-node'));