Estilização e CSS
Como eu adiciono classes de CSS nos componentes?
Passe a string para a prop className
:
render() {
return <span className="menu navigation-menu">Menu</span>
}
É comum para classes do CSS dependerem de props ou o state do componente.
render() {
let className = 'menu';
if (this.props.isActive) {
className += ' menu-active';
}
return <span className={className}>Menu</span>
}
Dica
Se você frequentemente se vê escrevendo código assim, o pacote classnames pode simplicar isso.
Posso utilizar estilo inline?
Sim, veja os docs sobre estilização aqui.
É ruim utilizar estilos inline?
Classes CSS geralmente possuem melhor performance que estilos inline.
O que é CSS-in-JS?
“CSS-in-JS” se refere a um padrão onde o CSS é definido utilizando JavaScript no lugar de arquivos externos.
Note que esta funcionalidade não faz parte do React, mas é fornecida por bibliotecas de terceiros. React não possui uma opinião sobre como os estilos são definidos; se estiver em dúvida, um bom ponto de partida é definir seus estilos em um arquivo .css
separado e referenciá-los usando className
.
Posso fazer animações em React?
O React pode ser usado para animações. Veja React Transition Group e React Motion ou React Spring, por exemplo.