Skip to content

Next.js

// TODO: link para exemplos

Começando com UnoCSS e Next.js.

Configuração

Instalação

bash
pnpm add -D unocss @unocss/webpack
bash
yarn add -D unocss @unocss/webpack
bash
npm install -D unocss @unocss/webpack
bash
bun add -D unocss @unocss/webpack

Configuração

Crie uno.config.ts na raiz do seu projeto.

ts
import {
  defineConfig,
  presetAttributify,
  presetIcons,
  presetWebFonts,
  presetWind3
} from 'unocss'

export default defineConfig({
  presets: [
    presetWind3(),
    // ...
  ],
})

Adicionar plugin

Em seguida, adicione o UnoCSS como um plugin do webpack através do seu next.config.js.

js
// next.config.js
const UnoCSS = require('@unocss/webpack').default

/** @type {import('next').NextConfig} */
const nextConfig = {
  reactStrictMode: true,
  webpack: (config) => {
    config.plugins.push(
      UnoCSS(),
    )
    return config
  },
}

module.exports = nextConfig

Importar folhas de estilo

Em seguida, importe uno.css em _app.tsx.

tsx
import type { AppProps } from 'next/app'
// _app.tsx
import '@unocss/reset/tailwind.css'

import 'uno.css'

function MyApp({ Component, pageProps }: AppProps) {
  return <Component {...pageProps} />
}

export default MyApp

Uso

Estilize seus componentes com unocss!

tsx
/* index.tsx */
const Home: NextPage = () => {
  return (
    <>
      <main className="py-20 px-12 text-center flex flex-col items-center gap-20px">
        <span text="blue 5xl hover:red" cursor="default">Nextjs</span>
        <div className="i-carbon-car inline-block" text="4xl" />
        <button className="btn w-10rem">Button</button>
      </main>
    </>
  )
}

Hot Module Reload

Para suportar HMR, você precisa desativar o cache do webpack.

js
// next.config.js
const nextConfig = {
  reactStrictMode: true,
  webpack: (config) => {
+   config.cache = false
    config.plugins.push(UnoCSS())
    return config
  }
}

Solução de problemas

Erro relacionado a módulo virtual

bash
Error: ENOENT: no such file or directory, open '.../_virtual_/__uno.css'

Tente excluir o diretório .next e reinicie o servidor de desenvolvimento.

Outros

Você pode precisar aumentar seu destino para pelo menos es2015 no seu tsconfig.json para construir seu projeto.

Arquivos com extensão .js não são suportados por padrão. Altere suas extensões de arquivo para .jsx ou tente incluir arquivos js na sua configuração com include: /\.js$/. Saiba mais.

Released under the MIT License.