Tailwind CSS
Komponens gondolkodás Tailwind-del
Komponens absztrakció React-ban, utility vs component, mikor custom CSS.
Komponens gondolkodás Tailwind-del
A probléma: copy-paste és ismétlés
Ha ugyanolyan gombot 20 helyen kell megjeleníteni, és mindenhol ugyanazokat a class-eket írjuk ki, az nem fenntartható:
<!-- Ez nem jó: 20 helyen ugyanez -->
<button class="bg-blue-500 hover:bg-blue-600 text-white font-semibold px-4 py-2 rounded-lg transition-colors">
Gomb 1
</button>
<button class="bg-blue-500 hover:bg-blue-600 text-white font-semibold px-4 py-2 rounded-lg transition-colors">
Gomb 2
</button>A megoldás: komponens absztrakció
React / Next.js-ben a megoldás nem a CSS elvonatkoztatása, hanem a JSX komponens elvonatkoztatása:
// components/Button.tsx
interface ButtonProps {
children: React.ReactNode;
variant?: 'primary' | 'secondary' | 'danger';
size?: 'sm' | 'md' | 'lg';
onClick?: () => void;
}
export function Button({ children, variant = 'primary', size = 'md', onClick }: ButtonProps) {
const base = 'font-semibold rounded-lg transition-colors focus:outline-none focus:ring-2 focus:ring-offset-2';
const variants = {
primary: 'bg-blue-500 hover:bg-blue-600 text-white focus:ring-blue-500',
secondary: 'bg-gray-100 hover:bg-gray-200 text-gray-900 focus:ring-gray-500',
danger: 'bg-red-500 hover:bg-red-600 text-white focus:ring-red-500',
};
const sizes = {
sm: 'px-3 py-1.5 text-sm',
md: 'px-4 py-2 text-base',
lg: 'px-6 py-3 text-lg',
};
return (
<button
className={`${base} ${variants[variant]} ${sizes[size]}`}
onClick={onClick}
>
{children}
</button>
);
}Használat:
<Button variant="primary" size="lg">Beküldés</Button>
<Button variant="secondary">Mégse</Button>
<Button variant="danger" size="sm">Törlés</Button>Utility vs Component – mikor mit?
| Helyzet | Ajánlott megközelítés |
|---|---|
| Egyedi, egyszeri elem | Utility class-ek közvetlenül |
| 2+ helyen ismétlődő elem | JSX komponens |
| Komplex state-függő stílusok | JSX komponens + clsx |
| Design token (szín, spacing) | @theme konfiguráció |
| Ismétlődő alap elem (pl. form input) | @layer components + @apply |
Mikor érdemes custom CSS-t írni?
- Komplex animációkhoz, ahol a
transitionnem elég - CSS
clip-path,mask,filterexotikus értékekhez - Harmadik fél UI könyvtár stílusainak felülbírálásához