ویژگی تصویر

افکت انیمیشنی برای اسکرول با CSS

  /  CSS   /  افکت انیمیشنی برای اسکرول با CSS
بنر تبلیغاتی الف

افکت‌های انیمیشنی هنگام اسکرول (Scroll Animations) ابزار قدرتمندی برای هدایت نگاه کاربر، افزایش تعامل و بهبود تجربه کاربری هستند. این افکت‌ها می‌توانند برای نمایان شدن عناصر، پارالکس، نوار پیشرفت اسکرول و جلوه‌های انتقال محتوا استفاده شوند. در این مقاله روش‌های مرسوم با تمرکز بر CSS و راهکارهای عملی، نکات بهینه‌سازی و نمونه‌های کاربردی را بررسی می‌کنیم.

انواع رایج افکت‌های اسکرول

  • Reveal on scroll — نمایان شدن عناصر هنگام ورود به ویوپورت
  • Parallax — حرکت لایه‌ها با سرعت‌های متفاوت
  • Sticky effects — چسبندگی و تغییر حالت عناصر هنگام پیمایش
  • Scroll progress — نمایش درصد یا خط پیشرفت اسکرول
  • Scroll-linked animations («CSS Scroll-Linked Animations» با @scroll-timeline)

1. نمایان شدن (Reveal) با ترکیب CSS و Intersection Observer (عملی و سازگار)

// HTML
<section class="content">
<div class="card reveal">Card 1</div>
<div class="card reveal">Card 2</div>
<div class="card reveal">Card 3</div>
</section>
/* CSS */ .reveal { opacity: 0; transform: translateY(30px); transition: opacity 600ms ease, transform 600ms ease; will-change: opacity, transform; } .reveal.is-visible { opacity: 1; transform: translateY(0); } /* JS */ const observer = new IntersectionObserver((entries) => { entries.forEach(entry => { if (entry.isIntersecting) { entry.target.classList.add('is-visible'); observer.unobserve(entry.target); } }); }, { threshold: 0.15 }); document.querySelectorAll('.reveal').forEach(el => observer.observe(el));

توضیح: این مثال از CSS برای تعریف انیمیشن (opacity و transform) و از JavaScript (Intersection Observer) برای تشخیص ورود عنصر به ویوپورت استفاده می‌کند. وقتی عنصر حداقل 15٪ قابل دید شود، کلاس is-visible اضافه شده و عنصر با انتقال نرم ظاهر می‌شود. این روش از نظر عملکرد خوب است چون مرورگرها عملیات را به صورت بهینه انجام می‌دهند و از reflowهای سنگین اجتناب می‌شود.

2. افکت پارالکس ساده با CSS فقط (سازگاری بالا)

/* HTML structure:
<section class="parallax">
<div class="bg"></div>
<div class="content">...content...</div>
</section>
*/ /* CSS */ .parallax { position: relative; overflow: hidden; height: 60vh; } .parallax .bg { background-image: url('path/to/image.jpg'); background-size: cover; background-position: center; position: absolute; inset: 0; background-attachment: fixed; /* simple parallax */ transform: translateZ(0); } .parallax .content { position: relative; z-index: 1; padding: 2rem; color: white; }

توضیح: این روش با استفاده از background-attachment: fixed یک پارالکس ساده ایجاد می‌کند. مزیت آن سادگی و پشتیبانی گسترده است، اما در موبایل‌ها ممکن است رفتار متفاوتی داشته باشد یا توسط برخی مرورگرها بهینه نباشد.

3. انیمیشن‌های لینک‌شده به اسکرول با @scroll-timeline (جدید و قدرتمند)

/* CSS */@scroll-timeline my-timeline {
  source: auto;
  orientation: block;
}

.box {
  height: 200px;
  background: coral;
  animation: fadeMove 1s linear both;
  animation-timeline: my-timeline;
  animation-range: 0% 50%; /* play between 0% and 50% of scroll */}

@keyframes fadeMove {
  from { opacity: 0; transform: translateY(50px); }
  to { opacity: 1; transform: translateY(0); }
}

توضیح: این نمونه از مشخصه‌های جدید CSS برای لینک کردن انیمیشن به اسکرول استفاده می‌کند. @scroll-timeline و animation-timeline به شما امکان می‌دهند انیمیشن را مستقیماً بر اساس موقعیت اسکرول کنترل کنید. نکته مهم این است که پشتیبانی مرورگرها هنوز کامل نیست (در حال حاضر مرورگرهای کرومیوم محور از آن پشتیبانی بهتری دارند) و باید برای مرورگرهای قدیمی fallback تعریف کنید.

4. نوار پیشرفت اسکرول (CSS + JS ساده)

// HTML
<div id="progress" class="progress"></div>
// CSS .progress { position: fixed; top: 0; left: 0; height: 4px; background: linear-gradient(90deg, #4caf50, #8bc34a); width: 0%; z-index: 9999; } // JS window.addEventListener('scroll', () => { const doc = document.documentElement; const scroll = (doc.scrollTop) / (doc.scrollHeight - doc.clientHeight); document.getElementById('progress').style.width = (scroll * 100) + '%'; });

توضیح: این کد یک نوار پیشرفت بالای صفحه ایجاد می‌کند که درصد اسکرول را نشان می‌دهد. با استفاده از ویژگی‌های DOM و محاسبه کردن نسبت اسکرول، عرض نوار تغییر می‌کند. این روش سبک و قابل فهم است اما از فراخوانی‌های زیاد صفحه بهینه‌سازی لازم است؛ در صورت نیاز از روتین‌های throttle/debounce استفاده کنید.

نکات حرفه‌ای در پیاده‌سازی افکت‌های اسکرول

  • عملکرد: از transform (translate, scale) و opacity برای انیمیشن استفاده کنید تا از repaint و reflow سنگین جلوگیری شود.
  • will-change: برای عناصر مهم از will-change با احتیاط استفاده کنید تا GPU را آماده کنید، اما از مصرف زیاد خودداری کنید.
  • prefers-reduced-motion: برای دسترسی‌پذیری احترام بگذارید و انیمیشن‌ها را برای کاربرانی که حرکت را محدود کرده‌اند خاموش کنید.
/* prefers-reduced-motion example */@media (prefers-reduced-motion: reduce) {
  .reveal, .box {
    transition: none !important;
    animation: none !important;
  }
}

توضیح: این قطعه CSS بررسی می‌کند که آیا کاربر تنظیم کاهش حرکت را در سیستم عامل فعال کرده است یا خیر؛ در این صورت انیمیشن‌ها غیرفعال می‌شوند تا تجربه دسترس‌پذیرتری فراهم شود.

جدول مقایسه تکنیک‌ها (مزایا و معایب)

تکنیکمزایامعایب
CSS + Intersection Observerسازگار، عملکرد مناسب، کنترل دقیقنیاز به JS کوچک
background-attachment: fixed (پارالکس)ساده، بدون JSمشکلات در موبایل و بعضی مرورگرها
@scroll-timelineقدرت و انعطاف بالا، بدون JS برای برخی سناریوهاپشتیبانی مرورگر محدود، نیاز به fallback

پیشنهادات نهایی و چک‌لیست قبل از انتشار

  • از انتقال‌های مبتنی بر transform و opacity استفاده کنید.
  • فال‌بک برای مرورگرهای قدیمی در نظر بگیرید (مثلاً نمایش ساده بدون انیمیشن یا استفاده از JS).
  • برای عناصر تکراری از lazy-loading و unobserve کردن بعد از نمایش استفاده کنید.
  • آزمون با ابزارهای پروفایل مرورگر و بررسی مصرف CPU و repaint.
  • تست دسترس‌پذیری: keyboard navigation و prefers-reduced-motion.

با ترکیب روش‌های فوق می‌توانید افکت‌های اسکرول زیبا، سریع و دسترس‌پذیر بسازید. انتخاب بین پیاده‌سازی pure-CSS یا ترکیب CSS+JS به نیاز پروژه، مخاطب هدف و میزان پشتیبانی مرورگرها بستگی دارد.

آیا این مطلب برای شما مفید بود ؟

خیر
بله
موضوعات شما در انجمن: