Tips & Tricks

Claude Code로 애니메이션 구현하기

Claude Code를 사용한 애니메이션 구현 방법을 알아봅니다. 실용적인 코드 예시와 단계별 가이드를 포함합니다.

Claude Code로 애니메이션 구현 효율화하기

웹 애니메이션은 사용자 경험을 크게 향상시키지만, 구현에는 전문 지식이 필요합니다. Claude Code를 사용하면 “페이드인 하고 싶어”, “스크롤 시 요소를 표시하고 싶어”라고만 전달해도 적절한 애니메이션 코드를 생성할 수 있습니다.

CSS 애니메이션 기본

먼저 CSS만으로 구현할 수 있는 애니메이션입니다.

> 스크롤 시 화면에 들어오면 페이드인하는 CSS 애니메이션을 만들어줘.
> 아래에서 슬라이드하며 나타나는 패턴도 포함해줘.
/* 페이드인 + 슬라이드 업 */
@keyframes fadeInUp {
  from {
    opacity: 0;
    transform: translateY(20px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes fadeInLeft {
  from {
    opacity: 0;
    transform: translateX(-20px);
  }
  to {
    opacity: 1;
    transform: translateX(0);
  }
}

.animate-fade-in-up {
  animation: fadeInUp 0.6s ease-out forwards;
}

.animate-fade-in-left {
  animation: fadeInLeft 0.6s ease-out forwards;
}

/* 초기 상태는 숨김 */
.animate-on-scroll {
  opacity: 0;
}

.animate-on-scroll.is-visible {
  animation: fadeInUp 0.6s ease-out forwards;
}

/* 스태거(지연) 애니메이션 */
.stagger-1 { animation-delay: 0.1s; }
.stagger-2 { animation-delay: 0.2s; }
.stagger-3 { animation-delay: 0.3s; }
.stagger-4 { animation-delay: 0.4s; }

Intersection Observer와 함께 사용합니다.

function setupScrollAnimations() {
  const observer = new IntersectionObserver(
    (entries) => {
      entries.forEach((entry) => {
        if (entry.isIntersecting) {
          entry.target.classList.add("is-visible");
          observer.unobserve(entry.target);
        }
      });
    },
    { threshold: 0.1, rootMargin: "0px 0px -50px 0px" }
  );

  document.querySelectorAll(".animate-on-scroll").forEach((el) => {
    observer.observe(el);
  });
}

document.addEventListener("DOMContentLoaded", setupScrollAnimations);

Framer Motion을 활용한 애니메이션

React 프로젝트에서는 Framer Motion을 사용하면 더 선언적으로 작성할 수 있습니다.

import { motion, useInView, type Variants } from "framer-motion";
import { useRef } from "react";

const containerVariants: Variants = {
  hidden: { opacity: 0 },
  visible: {
    opacity: 1,
    transition: {
      staggerChildren: 0.1,
    },
  },
};

const itemVariants: Variants = {
  hidden: { opacity: 0, y: 20 },
  visible: {
    opacity: 1,
    y: 0,
    transition: { duration: 0.5, ease: "easeOut" },
  },
};

export function AnimatedList({ items }: { items: string[] }) {
  const ref = useRef(null);
  const isInView = useInView(ref, { once: true, margin: "-50px" });

  return (
    <motion.ul
      ref={ref}
      variants={containerVariants}
      initial="hidden"
      animate={isInView ? "visible" : "hidden"}
      className="space-y-4"
    >
      {items.map((item, i) => (
        <motion.li key={i} variants={itemVariants} className="p-4 bg-white rounded-lg shadow">
          {item}
        </motion.li>
      ))}
    </motion.ul>
  );
}

페이지 트랜지션

페이지 전환 시의 애니메이션입니다.

import { motion, AnimatePresence } from "framer-motion";
import { useRouter } from "next/router";

const pageVariants: Variants = {
  initial: { opacity: 0, x: -20 },
  animate: { opacity: 1, x: 0 },
  exit: { opacity: 0, x: 20 },
};

export function PageTransition({ children }: { children: React.ReactNode }) {
  const router = useRouter();

  return (
    <AnimatePresence mode="wait">
      <motion.div
        key={router.pathname}
        variants={pageVariants}
        initial="initial"
        animate="animate"
        exit="exit"
        transition={{ duration: 0.3, ease: "easeInOut" }}
      >
        {children}
      </motion.div>
    </AnimatePresence>
  );
}

로딩 애니메이션

export function SkeletonLoader({ lines = 3 }: { lines?: number }) {
  return (
    <div className="space-y-3 animate-pulse">
      {Array.from({ length: lines }).map((_, i) => (
        <div
          key={i}
          className="h-4 bg-gray-200 rounded"
          style={{ width: `${100 - i * 15}%` }}
        />
      ))}
    </div>
  );
}

export function SpinnerLoader({ size = "md" }: { size?: "sm" | "md" | "lg" }) {
  const sizeClasses = { sm: "h-4 w-4", md: "h-8 w-8", lg: "h-12 w-12" };

  return (
    <div className={`${sizeClasses[size]} animate-spin rounded-full border-2 border-gray-300 border-t-primary-600`} />
  );
}

디자인 시스템과의 통합은 디자인 시스템 구축을, 반응형 대응은 반응형 디자인을 확인하세요.

정리

Claude Code를 활용하면 CSS 애니메이션, Framer Motion, 페이지 트랜지션, 로딩 표시까지 애니메이션 구현을 단시간에 완료할 수 있습니다. “이런 움직임을 넣고 싶어”라고만 전달하면 적절한 기술 선정과 코드 생성이 이루어집니다.

자세한 내용은 Claude Code 공식 문서를 참고하세요.

#Claude Code #animation #CSS #Framer Motion #frontend