DEV Community

Cover image for As Vantagens do Tailwind CSS em Projetos ReactJS
Andrey Araújo
Andrey Araújo

Posted on

As Vantagens do Tailwind CSS em Projetos ReactJS

O desenvolvimento de aplicações web utilizando ReactJS tem se tornado cada vez mais popular devido à sua flexibilidade e eficiência. Quando combinado com o framework Next.js, os desenvolvedores têm acesso a uma experiência de desenvolvimento ainda mais robusta e otimizada. Principalmente quando se trata da última versão do Next.js e do ReactJS.

Neste artigo, exploraremos as vantagens de integrar o Tailwind CSS em projetos ReactJS, com foco especial nas melhorias que ele pode oferecer quando utilizado com o Next.js. Além disso, vou mostrar uma alternativa interessante, o ShadcnUI, que pode ser integrado de forma complementar ao TailwindCSS, trazendo ainda mais agilidade na criação de interfaces.

Tailwind CSS

O Tailwind CSS é um framework CSS utilitário que proporciona uma abordagem única para o desenvolvimento de interfaces. Ele permite aos desenvolvedores criar designs personalizados diretamente em suas marcações. Diferente de outras bibliotecas CSS, como Bootstrap ou Material UI, que oferecem componentes predefinidos, Tailwind fornece classes utilitárias que você pode combinar para criar designs únicos.

Suas vantagens são especialmente evidentes ao trabalhar com ReactJS e, mais ainda, em projetos Next.js. Algumas das principais vantagens incluem:

  • Produtividade Aprimorada: Com classes utilitárias predefinidas, p-10 flex m-2 por exemplo, o Tailwind acelera o desenvolvimento ao eliminar a necessidade de escrever CSS do zero. Isso resulta em um fluxo de trabalho mais ágil e produtivo para os desenvolvedores ReactJS.
  • Estilo Consistente: O Tailwind promove um estilo consistente em todo o projeto, graças às suas classes padronizadas. Isso simplifica a manutenção do código e garante uma experiência de usuário coesa. Então chega de perder tempo escolhendo nome para classes CSS!
  • Customização Flexível: Apesar de suas classes predefinidas, o Tailwind é altamente customizável. Isso permite que os desenvolvedores personalizem o design de acordo com as necessidades específicas do projeto, mantendo a flexibilidade do ReactJS.

A Integração Perfeita com Next.js

Ao integrar o Tailwind CSS em projetos Next.js, as vantagens mencionadas são ainda mais perceptíveis. Next.js oferece um sistema de roteamento eficiente e renderização otimizada, enquanto o Tailwind simplifica o styling. Juntos, eles proporcionam um ambiente de desenvolvimento dinâmico e eficaz.

  • Otimização de Desempenho: A natureza modular do Tailwind se alinha perfeitamente com a abordagem de componentes do React e Next.js. Isso resulta em um código mais otimizado e em um desempenho geral aprimorado da aplicação.
  • Server-Side Rendering (SSR) e Static Site Generation (SSG): O Next.js suporta SSR e SSG, e ao integrar o Tailwind, a aplicação mantém um estilo consistente mesmo ao ser renderizada no servidor. Isso é crucial para garantir uma experiência do usuário mais suave.

O que vejo falar sobre o Tailwind

Tem um tempo já que pesquiso sobre esse framework, e como ele vem crescendo dentro da comunidade. Mas já vi muitos comentários do tipo: “ele só adiciona complexidade ao projeto”, “os arquivos React ficam enormes adicionando tantas classes nos elementos HTML”, e por ai vai.

Confesso que no começo vi dessa forma, mas depois de começar a usar, a fazer vários testes, e recentemente usar em projetos do trabalho, mudei totalmente de ideia, e hoje vejo que esse framework traz mais vantagens do que desvantagens.

Uma das vantagens do React é a possibilidade de componentizar elementos da nossa aplicação, e isso vai de encontro com a construção de interfaces usando Tailwind, por mais que as vezes precisemos adicionar bastante classes para estilizar um componente, vai do desenvolvedor analisar cada situação e componentizar o que for preciso, para não termos aqueles arquivos gigantes que adoramos dar manutenção. (contém ironia)

E por mais que o Tailwind já traga bastante agilidade no desenvolvimento de interfaces, vou te mostrar uma outra ferramenta que vai te trazer ainda mais.

ShadcnUI com TailwindCSS

Enquanto o Tailwind CSS é excepcional para a estilização utilitária, às vezes é desejável adicionar elementos de design mais complexos, ou que já tenham uma certa estilização pronta, para termos mais agilidade na criação de interfaces. É aqui que o ShadcnUI entra em cena. Este é um conjunto de componentes UI que podem ser facilmente integrados com o Tailwind, adicionando uma camada extra de estilo e interatividade.

  • Componentes Prontos para Uso: O ShadcnUI oferece uma variedade de componentes prontos para uso, como botões, cards e modais, que podem ser facilmente integrados a projetos ReactJS com Tailwind, apenas fazendo uma instalação do componente.
  • Estilo Elegante e Responsivo: Os componentes do ShadcnUI são projetados para serem elegantes e responsivos, complementando o estilo utilitário do Tailwind. Isso permite que os desenvolvedores alcancem uma estética visualmente atraente sem sacrificar a eficiência do desenvolvimento.
  • Tamanho do framework: O ShadcnUI não é igual ao MaterialUi, ou ChakraUI, que no momento da instalação já adiciona todos dos componentes disponíveis para usar. Nós fazemos a instalação apenas do componente que iremos usar, sendo totalmente customizável com as classes do tailwind. Isso eu vejo como uma grande vantagem.

    npx shadcn-ui@latest add button
    

Conclusão

Ao escolher Tailwind CSS para estilização em projetos ReactJS, especialmente em conjunto com Next.js, os desenvolvedores podem alcançar uma eficiência e consistência notáveis. A adição do ShadcnUI oferece uma alternativa interessante para projetos que exigem componentes mais elaborados. Experimente essa combinação poderosa e impulsione seus projetos ReactJS para novos patamares de desenvolvimento eficiente e estilo envolvente.

Se quiserem um vídeo mostrando essas ferramentas, desde instalação até a utilização em projetos reais, deixem ai nos comentários. 😉

Links úteis

ShadcnUI: https://ui.shadcn.com/docs
Tailwind CSS: https://tailwindcss.com/docs/installation

Top comments (2)

Collapse
 
raulferreirasilva profile image
Raul Ferreira

Opa cara gostaria de ver um vídeo na pratica sim, explicando melhor sobre o assunto com exemplos reais e boas praticas de programação, sempre bom ver como outras pessoas fazem as coisas para evoluir junto com elas. Muito obrigado por transmitir seu conhecimento 🦤.

Collapse
 
corners2wall profile image
Corners 2 Wall

In my view, when you use tailwind for middle/big projects(from 100k lines) in this case tailwinds looks like hype technology.
Not scalable, non profit. In my opinion it's bootstrap 2.0.