Next.js
Начало работы с UnoCSS и Next.js. Ознакомьтесь с примером.
Настройка
Установка
bash
pnpm add -D unocss @unocss/postcss @unocss/resetbash
yarn add -D unocss @unocss/postcss @unocss/resetbash
npm install -D unocss @unocss/postcss @unocss/resetbash
bun add -D unocss @unocss/postcss @unocss/resetКонфигурация
Создайте uno.config.ts или uno.config.js в корневой директории вашего проекта.
ts
import {
defineConfig,
presetAttributify,
presetIcons,
presetWebFonts,
presetWind3
} from 'unocss'
export default defineConfig({
presets: [
presetWind3(),
// ...
],
})js
import {
defineConfig,
presetAttributify,
presetIcons,
presetWebFonts,
presetWind3
} from 'unocss'
export default defineConfig({
presets: [
presetWind3(),
// ...
],
})Создайте postcss.config.mjs в корневой директории вашего проекта.
js
export default {
plugins: {
'@unocss/postcss': {
content: ['./app/**/*.{html,js,ts,jsx,tsx}'],
},
},
}Импорт таблиц стилей
Добавьте @unocss all; в globals.css:
css
@unocss all;
/* ... */Затем импортируйте @unocss/reset/tailwind.css в ваш файл макета (layout):
tsx
import type { Metadata } from 'next'
import { Geist, Geist_Mono } from 'next/font/google'
import '@unocss/reset/tailwind.css'
import './globals.css'
const geistSans = Geist({
variable: '--font-geist-sans',
subsets: ['latin'],
})
const geistMono = Geist_Mono({
variable: '--font-geist-mono',
subsets: ['latin'],
})
export const metadata: Metadata = {
title: 'Create Next App',
description: 'Generated by create next app',
}
export default function RootLayout({
children,
}: Readonly<{
children: React.ReactNode
}>) {
return (
<html lang="en">
<body
className={`${geistSans.variable} ${geistMono.variable} antialiased`}
>
{children}
</body>
</html>
)
}js
import { Geist, Geist_Mono } from 'next/font/google'
import '@unocss/reset/tailwind.css'
import './globals.css'
const geistSans = Geist({
variable: '--font-geist-sans',
subsets: ['latin'],
})
const geistMono = Geist_Mono({
variable: '--font-geist-mono',
subsets: ['latin'],
})
export const metadata = {
title: 'Create Next App',
description: 'Generated by create next app',
}
export default function RootLayout({ children }) {
return (
<html lang="en">
<body className={`${geistSans.variable} ${geistMono.variable}`}>
{children}
</body>
</html>
)
}Использование
Стилизуйте свои компоненты с помощью unocss!
tsx
export default function Home() {
return (
<main className="py-20 px-12 text-center flex flex-col items-center gap-20px">
<span className="text-blue text-5xl text-hover:red cursor-default">Nextjs</span>
<div className="i-carbon-car inline-block text-4xl" />
<button className="btn w-10rem">Кнопка</button>
</main>
)
}js
export default function Home() {
return (
<main className="py-20 px-12 text-center flex flex-col items-center gap-20px">
<span className="text-blue text-5xl text-hover:red cursor-default">Nextjs</span>
<div className="i-carbon-car inline-block text-4xl" />
<button className="btn w-10rem">Кнопка</button>
</main>
)
}Лицензия
- Лицензия MIT © 2021-настоящее время Anthony Fu