ویژگی تصویر

ساخت افکت ترنزیشن هموار با CSS

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

ترنزیشن‌های هموار (Smooth Transitions) در رابط‌های کاربری نقش بسیار مهمی دارند: تجربه کاربری را دلپذیرتر می‌کنند، تعاملات را قابل‌فهم‌تر می‌سازند و حس کیفیت را افزایش می‌دهند. در این مقاله به صورت عملی و با مثال‌های واقعی، اصول، تکنیک‌ها و نکات بهینه‌سازی برای ساخت ترنزیشن‌های روان با CSS را بررسی می‌کنیم.

اصول پایه ترنزیشن در CSS

دو مفهوم اصلی در CSS برای حرکت و انیمیشن وجود دارد: transition و animation. برای افکت‌های ساده‌ای که از یک وضعیت به وضعیت دیگر تغییر می‌کنند، transition حداقل و مؤثر است. چهار پارامتر مهم برای transition عبارت‌اند از:

  • transition-property
  • transition-duration
  • transition-timing-function
  • transition-delay

مثال پایه — دکمه با ترنزیشن هموار

<button class="btn">Hover me</button>

.btn {
  background: #007bff;
  color: white;
  padding: 12px 20px;
  border: none;
  border-radius: 6px;
  cursor: pointer;
  transition: background-color 250ms ease, transform 200ms ease;
}

.btn:hover {
  background-color: #0056b3;
  transform: translateY(-4px);
}

این کد یک دکمه تعریف می‌کند که با هاور رنگ پس‌زمینه و موقعیت (با translateY) به صورت نرم تغییر می‌کنند. استفاده از transform به جای تغییر موقعیت‌های مبتنی بر left/top عملکرد بهتری دارد (GPU-accelerated).

تنظیمات کلیدی و معنی آن‌ها

خاصیتتوضیح
transition-propertyمشخص می‌کند کدام خاصیت(ها) هنگام تغییر متحرک شوند (مثلاً transform, opacity)
transition-durationمدت زمان ترنزیشن (مثل 200ms، 0.5s)
transition-timing-functionمنحنی زمان‌بندی (مثل ease، linear، cubic-bezier)
transition-delayتأخیر قبل از شروع ترنزیشن

تابع زمان‌بندی (timing-function) و تاثیر آن

تابع زمان‌بندی حس سرعت و شتاب حرکت را تعیین می‌کند. مثال‌های رایج: linear (ثابت)، ease (شروع آهسته و پایان آهسته)، ease-in (شروع آهسته)، ease-out (پایان آهسته)، cubic-bezier (کنترل کامل).

.box { transition: transform 600ms ease-out; }
.box.linear { transition-timing-function: linear; }
.box.bezier { transition: transform 600ms cubic-bezier(.22,1,.36,1); }

در این مثال سه حالت مختلف زمان‌بندی برای یک باکس نشان داده شده است. cubic-bezier به شما اجازه می‌دهد منحنی شتاب را دقیقاً مطابق نیاز تنظیم کنید (برای ایجاد حس “پرشی” یا “نرم”).

استفاده از transform و opacity برای عملکرد بهتر

برای روان بودن ترنزیشن، بهتر است از خواصی استفاده کنید که توسط GPU قابل بهینه‌سازی هستند: transform و opacity در این دسته‌اند. اجتناب کنید از تغییر خواصی مانند width، height، top، left یا margin برای انیمیشن‌های پیچیده که باعث ری‌فلوی کامل صفحه می‌شوند.

.card {
  transition: transform 300ms cubic-bezier(.2,.8,.2,1), opacity 200ms ease;
  will-change: transform, opacity;
}
.card:hover {
  transform: translateY(-10px) scale(1.03);
  opacity: 0.98;
}

در کد بالا از will-change برای اطلاع به مرورگر دربارهٔ خواص قابل تغییر استفاده شده تا مرورگر بتواند بهینه‌سازی‌های لازم (مثل ایجاد لایهٔ ترکیبی) را انجام دهد. با این کار ترنزیشن‌ها روان‌تر می‌شوند، ولی نباید will-change را برای مدت طولانی روی تعداد زیادی از عناصر گذاشت چون می‌تواند حافظه را مصرف کند.

ترنزیشن همزمان چند خاصیت

گاهی لازم است چند خاصیت به‌صورت همزمان و با زمان‌بندی‌های متفاوت تغییر کنند. می‌توان آن‌ها را در یک دستور transition جدا کرد.

.profile {
  transition: transform 300ms ease, opacity 200ms ease-in-out, box-shadow 350ms ease;
}
.profile:hover {
  transform: translateY(-8px);
  opacity: 1;
  box-shadow: 0 12px 24px rgba(0,0,0,0.12);
}

این الگو برای کارت‌ها یا کارت‌های پروفایل مناسب است: حرکت جزئی، افزایش سایه برای حس عمق و تغییر شفافیت برای برجسته‌سازی. تفکیک زمان‌ها و توابع زمانی به کنترل دقیق‌تر منجر می‌شود.

ترنزیشن با کلاس‌ها و جاوااسکریپت

برای تعاملات پیچیده‌تر، معمولاً با افزودن/حذف کلاس توسط جاوااسکریپت وضعیت‌ها را تغییر می‌دهیم و CSS مسئول ترنزیشن است.

const el = document.querySelector('.modal');
document.querySelector('.open-btn').addEventListener('click', () => {
  el.classList.add('is-open');
});
document.querySelector('.close-btn').addEventListener('click', () => {
  el.classList.remove('is-open');
});

/* CSS */.modal {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 240ms ease, transform 240ms ease;
  pointer-events: none;
}
.modal.is-open {
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}

جاوااسکریپت تنها وظیفهٔ مدیریت کلاس‌ها را دارد؛ خود افکت‌ها در CSS تعریف شده‌اند. استفاده از pointer-events به مخفی‌سازی تعامل در حالت بسته کمک می‌کند.

بهینه‌سازی و دسترسی

  • از will-change هوشمندانه استفاده کنید و آن را حذف کنید زمانی که دیگر نیاز نیست.
  • به کاربران با ترجیح کاهش حرکت (prefers-reduced-motion) احترام بگذارید.
  • از تغییر خواص کم‌هزینه مانند transform و opacity استفاده کنید.
  • ترنزیشن‌های کوتاه‌تر برای عناصر تعاملی روزمره (100-300ms) مناسب‌اند؛ برای انتقال بین صفحات می‌توان از 300-600ms استفاده کرد.
@media (prefers-reduced-motion: reduce) {
  * {
    transition: none !important;
    animation: none !important;
  }
}

این قطعه کد به کاربرانی که حرکت را محدود کرده‌اند احترام می‌گذارد و تجربه را مطابق تنظیمات آن‌ها تنظیم می‌کند.

نمونه کامل: کارت شناور با جزئیات دسترسی

<div class="feature-card">
  <h4>Feature Title</h4>
  <p>Short description...</p>
</div>

/* CSS */.feature-card {
  background: white;
  border-radius: 12px;
  padding: 20px;
  box-shadow: 0 6px 18px rgba(0,0,0,0.06);
  transform: translateY(0);
  transition: transform 280ms cubic-bezier(.2,.8,.2,1), box-shadow 280ms ease;
  will-change: transform, box-shadow;
}
.feature-card:hover,
.feature-card:focus-within {
  transform: translateY(-10px);
  box-shadow: 0 20px 40px rgba(0,0,0,0.12);
}

این کارت برای کاربردهای UI مانند لیست ویژگی‌ها یا محصولات مناسب است. focus-within باعث می‌شود زمانی که آیتم‌های فرزند فوکوس می‌شوند نیز افکت اعمال شود و به دسترسی کمک می‌کند.

جمع‌بندی — نکات کلیدی برای ترنزیشن هموار

  • از transform و opacity برای کاهش بار راندربندی استفاده کنید.
  • تابع زمان‌بندی مناسب انتخاب کنید تا حس طبیعی‌تری ایجاد شود.
  • will-change را هوشمندانه و کوتاه‌مدت به کار ببرید.
  • همیشه به prefers-reduced-motion احترام بگذارید.
  • برای حالت‌های پیچیده، از ترکیب CSS و مدیریت کلاس در JS استفاده کنید تا Separation of Concerns حفظ شود.

با رعایت این اصول و تمرین با مثال‌های واقعی، می‌توانید ترنزیشن‌هایی بسازید که هم زیبا و هم بهینه باشند و تجربه کاربری را به طرز محسوسی بهبود دهند.

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

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