Uma foto minha vestido com o uniforme da Grifinória do Harry Potter

Willian JustenSoftware Engineer

Instrutor na Udemy, escrevo sobre o mundo front end, viagens, vida pessoal e mais.

← Voltar na listagem

#2 - Como usar o ReactJS

As diferentes formas de se usar e se iniciar um projeto com ReactJS.

Introdução

A trilha sonora fica por conta de Tame Impala, uma banda bastante psicodélica e que fez um dos melhores shows que já pude assistir =)

Como prometido, vou dar continuidade a série de posts sobre ReactJS e para acompanhar tanto essa série, como outras, é só ir no link series.

Iniciando

No post anterior eu falei um pouquinho do que era o React, como ele funciona e uma nova forma de se pensar em componentes que ele traz. Só que ficou faltando o mais importante, como usar?

Nesse post irei dar algumas alternativas de como trabalhar com o ReactJS, para assim já podermos começar a trabalhar ainda mais com ele. Lembrando que nenhuma das formas é a melhor, cada uma tem sua utilidade em determinado momento.

Não se preocupe com todos os detalhes dos códigos, pois iremos ver mais detalhadamente em outros posts. Não curto muito exemplos de Hello World, já que não ensinam nada, mas para esse caso será útil, visto que só quero mostrar as formas de uso.

Se você quiser se adiantar um pouco, aconselho a ir dando uma lida na API do React, que contém todos os comandos primários que vamos utilizar nos exemplos.

Arquivos

Para usar o React da forma mais simples, basta baixar esse template html deles, mas lembrando que é só uma página html com alguns links para carregar.

Você também pode utilizar a CDN deles, aqui tem os links

<script crossorigin src="https://unpkg.com/react@16/umd/react.production.min.js"></script>
<script crossorigin src="https://unpkg.com/react-dom@16/umd/react-dom.production.min.js"></script>

Básico sem JSX

Essa forma é a mais básica de todas e funciona como se fosse usar uma biblioteca normal de Javascript. Baixe o arquivo do React e chame no seu html:

<script src="react.js"></script>
<script src="react-dom.js"></script>

E logo após a chamada da biblioteca, coloque o seu script, seja ele inline ou chamando de um outro arquivo.

var ExampleApplication = createReactClass({
  render: function() {
    var elapsed = Math.round(this.props.elapsed  / 100);
    var seconds = elapsed / 10 + (elapsed % 10 ? '' : '.0' );
    var message =
      'O React está rodando com sucesso há ' + seconds + ' seconds.';
      return ReactDOMFactories.p(null, message);
    }
});

var ExampleApplicationFactory = React.createFactory(ExampleApplication);
var start = new Date().getTime();

setInterval(function() {
  ReactDOM.render(
    ExampleApplicationFactory({elapsed: new Date().getTime() - start}),
    document.getElementById('container')
  );
}, 50);

update: (02/06/2016) - na linha 16 atualizamos para utilizar o ReactDOM.render(), pois ele agora é separado do React original.

update: (16/05/2018) - na linha 1 atualizamos para utilizar createReactClass e na linha 8 atualizamos para ReactDOMFactories pois React.createClass e React.DOM foram marcados como deprecated na versão 15.0 e removidos na 16.0, para utilizá-los é necessário adicionar as bibliotecas create-react-class e react-dom-factories ao projeto

<script src="https://unpkg.com/create-react-class@15.6.3/create-react-class.min.js"></script>
<script src="https://unpkg.com/react-dom-factories@1.0.2/index.js"></script>

Utilizando o React em JS cru, necessitamos de algumas manipulações para criação de elementos ou utilizar alguns que o próprio React nos dá.

Como disse anteriormente, não se preocupe com todo o código, visto que irei falar sobre cada detalhe mais tarde. Só se atente as linhas 8, 12 e 17, que são as mais específicas para o caso de React sem JSX.

Na linha 8, estamos utilizando um factory built-in do React para selecionar a tag p no DOM e inserir o valor de message. Na linha 12 estamos criando um elemento de React com o método createFactory, que nos permitirá extendê-lo e utilizá-lo sempre que quisermos. Na linha 17, estamos chamando o elemento criado, passando a propriedade elapsed e seu valor. Essa sintaxe é mais verbosa e precisaremos escrever um pouco mais, mas ela é Javascript puro e os mais puristas, que reclamam de Html no JS, não podem reclamar.

Utilizando JSX

O JSX é uma sintaxe criada para o React, que se assemelha ao XML e que facilita bastante o nosso workflow. Se quiser saber um pouco mais sobre, aconselho este link.

Para usar essa sintaxe diretamente no Browser, precisamos do Babel e do React chamados no nosso html:

<script src="react.js"></script>
<script src="react-dom.js"></script>
<script src="https://unpkg.com/create-react-class@15.6.3/create-react-class.min.js"></script>
<script src="https://unpkg.com/react-dom-factories@1.0.2/index.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/babel-core/5.8.24/browser.min.js"></script>

Podemos ter o JSX de duas formas: inline, utilizando a tag <script type="text/jsx"> ou num arquivo externo com a extensão .jsx. Segue um exemplo usando um script inline:

update: (02/06/2016) - antigamente era utilizado o JSXTransformer, mas agora o Babel fica encarregado dessa mudança. Então, no type do script, precisamos colocar text/babel, para que o Babel consiga interpretar

var ExampleApplication = createReactClass({
  render: function() {
    var elapsed = Math.round(this.props.elapsed  / 100);
    var seconds = elapsed / 10 + (elapsed % 10 ? '' : '.0' );
    var message =
      'React has been successfully running for ' + seconds + ' seconds.';
      return <p>{message}</p>;
    }
});
var start = new Date().getTime();
setInterval(function() {
  ReactDOM.render(
    <ExampleApplication elapsed={new Date().getTime() - start} />,
    document.getElementById('container')
  );
}, 50);

As grandes diferenças nessa sintaxe estão na linha 8 e 14. Na linha 8, não necessitamos mais de utilizar função para criar um elemento, bastando apenas utilizar a tag html que quisermos. E na linha 14 é onde criamos nosso componente, que está recebendo suas devidas propriedades.

Utilizando o ES6 (Harmony)

Com o ES6 vindo aí com força total, o React passou a dar suporte a partir da versão 0.13.0 Beta 1. Com isso podemos utilizar de algumas features novas, como Classes, fat arrows, autobinding, mixins e etc. Se quiser saber um pouquinho mais sobre ES6, tem o site JSRocks, que é cheio de coisinhas bacanas.

update: (02/06/2016) - antes utilizámos o parâmetro harmony=true, agora é só passar que o tipo é text/babel para funcionar.

class ExampleApplication extends React.Component {
  render() {
    var elapsed = Math.round(this.props.elapsed  / 100);
    var seconds = elapsed / 10 + (elapsed % 10 ? '' : '.0' );
    var message =
      `React has been successfully running for ${seconds} seconds.`;
      return <p>{message}</p>;
  }
}
var start = new Date().getTime();
  setInterval(() => {
    ReactDOM.render(
    <ExampleApplication elapsed={new Date().getTime() - start} />,
    document.getElementById('container')
  );
}, 50);

O grande diferencial aqui fica por conta da criação de uma classe ExampleApplication e a extensão que fazemos de React.Component para criar o nosso componente. A utilização de ${} para concatenar uma variável e o uso do fat arrow => para nos facilitar e escrever menos, também são algumas das vantagens do ES6.

JS pré-compilado

Podemos escrever em JSX e antes de enviar para nosso servidor, podemos fazer um build compilando esse JSX para JS.

update: (02/06/2016) - Antigamente utilizávamos o react-tools para fazer esse trabalho de compilação. Mas agora fica tudo a cargo do babel. Onde instalamos a cli do babel e o seu preset para react.

npm install -g babel-cli
npm install babel-preset-react

E então rodarmos o compilador, definindo que o preset é react e para onde queremos jogar nosso código compilado.

babel example.js --presets react --out-dir=build

Basicamente o que muda aqui é que iremos escrever em JSX, mas o código a subir será JS puro.

Usando o CommonJS

Muita gente que trabalha com NodeJS está acostumada com a sintaxe dele e seu sistema modular, que é o padrão do CommonJS. O React também permite essa abordagem (que é linda <3).

Dessa forma, não precisamos chamar o React diretamente no nosso markup, visto que ele será chamado via require dentro do código e quando ele for compilado, já terá todo ele incluso. O trecho de código chamando o React seria:

var React = require('react');
var ReactDOM = require('react-dom');

Para esses casos, eu sempre opto por iniciar um projeto com o npm init e então instalo as dependências no meu projeto, para que fiquem na pasta node_modules. Para trabalhar com o CommonJS, eu utilizo bastante o Browserify, mas você também pode optar pelo Webpack, que inclusive é preferido pelos devs de React.

Para o browserify, basta instalar os seguintes módulos:

npm install browserify envify reactify react --save-dev

E para compilar usando o browserify, basta rodar:

browserify --debug --transform reactify index.js > bundle.js

Onde ele irá pegar o conteúdo de index.js e compilar para bundle.js.

Boilerplates

Existem alguns boilerplates lá no github que já vem com algumas estruturas bem organizadas, se você tiver interesse em ver como alguns organizam, seguem os links:

Também existem alguns posts bem interessantes sobre organizações:

Conclusão

Bom, agora que já sabemos para que serve e diversas formas de usar, já poderemos começar a brincar com alguns conceitos do React e fazer algumas brincadeiras, que irão começar no próximo post. Esse post ficou meio grande e talvez um pouco complexo, se tiverem alguma dúvida, só comentarem abaixo =)

Veja mais posts

Série sobre React