스크롤 트리거 애니메이션

· 4개월 전 · 305
스크롤할 때 요소가 부드럽게 등장하는 인터랙션은 사용자 주목도를 높이고 사이트의 완성도를 끌어올림. 핵심은 Intersection Observer API를 이용해 스크롤 이벤트 없이도 효율적으로 구현하는 것임.

<section class="fade-section">스크롤 시 나타나는 콘텐츠</section>
<section class="fade-section">두 번째 섹션</section>
<section class="fade-section">세 번째 섹션</section>

.fade-section {
opacity: 0;
transform: translateY(30px);
transition: all 0.6s ease;
}
.fade-section.show {
opacity: 1;
transform: translateY(0);
}

const options = { threshold: 0.2 };
const observer = new IntersectionObserver((entries, obs) => {
entries.forEach(entry => {
if(entry.isIntersecting){
entry.target.classList.add('show');
obs.unobserve(entry.target); // 한 번만 실행
}
});
}, options);

document.querySelectorAll('.fade-section').forEach(el => observer.observe(el));

스크롤 이벤트 대신 IntersectionObserver를 사용하면 성능 저하 없이 깔끔하게 구현 가능.

threshold는 화면에 몇 % 보였을 때 애니메이션을 시작할지 결정.

.show 클래스에 원하는 트랜지션 효과를 다양하게 줄 수 있음 (예: slide-in, scale-up 등).

라이브러리 사용 시엔 GSAP의 ScrollTrigger를 이용하면 훨씬 더 정교한 타이밍 조정 가능.

이렇게 하면 스크롤 위치에 따라 자연스럽게 콘텐츠가 등장하는 고급 인터랙션을 만들 수 있음.
|
댓글을 작성하시려면 로그인이 필요합니다.

퍼블리싱강좌

+
분류 제목 글쓴이 날짜 조회
CSS 2개월 전 조회 133
CSS 2개월 전 조회 226
CSS 3개월 전 조회 293
CSS 4개월 전 조회 306
CSS 5개월 전 조회 461
CSS 6개월 전 조회 540
CSS 6개월 전 조회 455
CSS 7개월 전 조회 457
CSS 7개월 전 조회 581
CSS 7개월 전 조회 527
CSS 7개월 전 조회 445
CSS 8개월 전 조회 467
CSS 8개월 전 조회 499
CSS 8개월 전 조회 468
CSS 8개월 전 조회 596
CSS 8개월 전 조회 557
CSS 8개월 전 조회 526
CSS 8개월 전 조회 528
CSS 8개월 전 조회 397
CSS 2년 전 조회 1,682
CSS 3년 전 조회 2,725
CSS 4년 전 조회 4,276
CSS 4년 전 조회 4,780
반응형웹 5년 전 조회 3,165
반응형웹 5년 전 조회 3,007
부트스트랩 8년 전 조회 5,198
부트스트랩
[부트스트랩]
8년 전 조회 6,798
부트스트랩 8년 전 조회 4,834
부트스트랩 8년 전 조회 6,892
부트스트랩 8년 전 조회 3,509