Learning
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?

HelyzetAjánlott megközelítés
Egyedi, egyszeri elemUtility class-ek közvetlenül
2+ helyen ismétlődő elemJSX komponens
Komplex state-függő stílusokJSX 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 transition nem elég
  • CSS clip-path, mask, filter exotikus értékekhez
  • Harmadik fél UI könyvtár stílusainak felülbírálásához

On this page