ویژگی تصویر

انیمیشن ساده با transition در CSS — مقدمه‌ای کاربردی

  /  CSS   /  انیمیشن ساده با transition در CSS
بنر تبلیغاتی الف

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

چرا از transition استفاده کنیم؟

  • نوشتن ساده و کم‌حجم: با چند خط CSS می‌توان افکت‌های جذاب ساخت.
  • کارایی خوب: اگر درست استفاده شود، مصرف پردازنده و GPU کم است.
  • قابل ترکیب با:hover, :focus و کلاس‌های جاوااسکریپت برای تعامل پویا.

ساختار پایه‌ی transition

قواعد پایه‌ی transition شامل چهار بخش است:

  • property — مشخص می‌کند کدام ویژگی (مثل background-color, transform) تغییر کند.
  • duration — مدت زمان انیمیشن (مثلاً 0.3s).
  • timing-function — منحنی زمانی (مثل ease, linear, cubic-bezier).
  • delay — تاخیر قبل از شروع انیمیشن.

مثال پایه — دکمه با hover

/* HTML

*/
/* CSS */.btn {
  background: #3498db;
  color: white;
  padding: 12px 20px;
  border: none;
  border-radius: 6px;
  cursor: pointer;
  transition: background-color 0.25s ease, transform 0.2s ease;
}

.btn:hover {
  background-color: #2980b9;
  transform: translateY(-3px);
}

در این مثال، وقتی نشانگر ماوس روی دکمه قرار می‌گیرد، رنگ پس‌زمینه تغییر و دکمه کمی بالا می‌آید. به کمک transition تغییرات به‌صورت نرم اتفاق می‌افتد. مشخص کرده‌ایم که هر دو ویژگی background-color و transform انیمیشن داشته باشند و مدت هر کدام جداگانه تعریف شده است.

مثال: استفاده از timing-function سفارشی

.card {
  transition: transform 0.5s cubic-bezier(.2,.8,.2,1);
}
.card:hover {
  transform: scale(1.04);
}

در این کد از تابع cubic-bezier برای کنترل دقیق سرعت انیمیشن استفاده شده است. این روش برای ایجاد اثرات “ارتجاعی” یا “کشش” عالی است و تجربه‌ی کاربری طبیعی‌تری می‌دهد.

ترکیب transform با GPU — بهینه‌سازی عملکرد

به جای تغییر مشخصه‌هایی مانند left یا top که باعث بازچینش (reflow) می‌شوند، بهتر است از transform (مثل translate, scale, rotate) استفاده کنید که اغلب توسط GPU شتاب داده می‌شوند. همچنین می‌توانید از will-change برای اطلاع به مرورگر استفاده کنید:

.item {
  will-change: transform, opacity;
  transition: transform 0.3s ease, opacity 0.3s ease;
}

will-change به مرورگر اجازه می‌دهد منابع لازم را از قبل آماده کند، اما نباید برای همه‌ عناصر به‌طور دائمی استفاده شود چون ممکن است حافظه بیشتری مصرف کند.

مقایسه کوتاه: transition vs animation

ویژگیtransitionanimation
کاربردتغییرات بین دو حالت (مثلاً hover)انیمیشن‌های پیچیده و چندمرحله‌ای
تعریفکوتاه و سادهنیاز به keyframes
کنترلمحدود به شروع/پایانقابل زمان‌بندی و حلقه‌دار

مثال پیشرفته: نوار ناوبری با انتقال رنگ و ارتفاع

.nav-item {
  padding: 10px 15px;
  transition: color 0.2s ease, background-color 0.2s ease, box-shadow 0.2s ease;
}
.nav-item:hover {
  color: #fff;
  background-color: #222;
  box-shadow: 0 4px 12px rgba(0,0,0,0.15);
}

در منوها تغییرات ظریف در رنگ و سایه می‌تواند تجربه‌ی کلی را بهبود بخشد. توجه کنید که تغییرات سایه نیز باید با دقت استفاده شوند تا عملکرد را تحت‌تأثیر قرار ندهند.

نکات دسترسی (Accessibility)

  • برای کاربران دارای اختلالات حرکتی یا حساس به حرکت، گزینه‌ای برای غیرفعال‌سازی انیمیشن‌ها در نظر بگیرید. می‌توانید از مدیا کوئری prefers-reduced-motion استفاده کنید.
  • مقادیر زمان را خیلی کوتاه یا خیلی بلند نکنید—مقادیر معمولی بین 0.15s تا 0.5s مناسب‌اند.
  • اطمینان یابید که انیمیشن باعث از بین رفتن خوانایی یا ناوبری نشود.

نمونه: رعایت prefers-reduced-motion

@media (prefers-reduced-motion: reduce) {
  .btn, .card, .nav-item {
    transition: none !important;
    animation: none !important;
  }
}

این قطعه کد به مرورگر می‌گوید اگر کاربر تنظیم کاهش حرکت را فعال کرده است، انیمیشن‌ها را غیرفعال کند؛ یک روش ساده و مؤثر برای احترام به ترجیحات کاربر.

اشتباهات رایج و راه‌حل‌ها

  • تغییر تمام ویژگی‌ها با transition: all: استفاده از all می‌تواند ناخواسته تغییراتی را انیمیت کند و کارایی را کاهش دهد. بهتر است فقط خصوصیات مورد نیاز را مشخص کنید.
  • استفاده بیش از حد از will-change: تنها برای عناصر مهم و زمانی که انیمیشن مکرر است، از آن استفاده کنید.
  • تداخل انیمیشن و جاوااسکریپت: هنگام اضافه‌کردن کلاس‌ها با JS، از رویدادهای پایان انیمیشن مثل transitionend برای هماهنگی استفاده کنید.

نتیجه‌گیری و موارد استفاده

transition در CSS ابزار قدرتمندی برای ایجاد انیمیشن‌های ساده و پاسخگو است. از آن برای دکمه‌ها، منوها، کارت‌ها و تغییرات وضعیت استفاده کنید تا رابط نرم‌تر و دلپذیرتری بسازید. با رعایت اصول بهینه‌سازی و دسترسی می‌توانید تجربه‌ای حرفه‌ای و سریع ارائه دهید.

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

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