انیمیشن در css چیست؟

انیمیشن در css چیست؟
آکادمی آی تی
آکادمی آی تی
dots

انیمیشن در css چیست؟

زمان مورد نیاز برای مطالعه 5 دقیقه

انیمیشن در CSS در صفحات وب به شما کمک میکند تا بتوانید یه صفحه پویا و زیبایی را ایجاد کنید تا کاربران را به خود جذب کند. آموزش animation در css از صفر تا صد.

دپارتمان ‌ها: آموزش طراحی سایت
1401/09/29
2,062 بازدید

آموزش انیمیشن در css

انیمیشن در css

 

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

ایجاد یک تجربه‌ عالی با تولید انیمشن های زیبا موجب می شود زیبایی و حرفه ای بودن وبسایت شما را تقویت کند. اگر به وبسایت های مختلف مشاهده کرده باشید استفاده از انیمیشن در سایت ها بسیار بیشتر شده است و با کمک ساخت انیمشن های جذاب css از یکنواختی و سادگی وبسایت جلوگیری کند. در ادامه این مقاله قصد داریم نحوه ایجاد انیمشن در css به شما آشنا کنیم؛ پس با ما همراه باشید.

انیمیشن در CSS چیست؟

با ایجاد انیمیشن در صفحات وب خود این امکان را به شما می دهد تا بتوانید یک المان را در طی مدت زمان مشخصی ویژگی های رفتاری و ظاهر خود را تغییر دهید. به طور کلی برای استفاده انیمیشن در css تنها کافیست با قرار دادن چندین کلیدواژه یک انیمشن زیبا را تولید کنید.

برای ساخت انیمیشن موردنظر خود در ابتدا باید دستور @Keyframes تعریف کنید و با کمک آن استایل های انیمیشن از جمله میزان تاخیر، تعداد دفعات تکرار و غیره مشخص کرد.

معرفی ویژگی های انیمیشن در css3

قبل از ساختن یک انیمیشن، در نظر داشته باشید که باید ویژگی هایی از جمله نام انیمیشن، مدت زمان، تعداد دفعات تکرار، منحنی سرعت و... مشخص کنید. تمام این ویژگی ها، به المانی که می خواهید انیمیشن داشته باشد اختصاص داده می‌شود. اختصاص دادن این ویژگی ها، مشابه تعیین خاصیت های یک transition می باشد که این ویژگی ها به شرح زیر است.

  • animation-name
  • animation-duration
  • animation-delay
  • animation-iteration-count
  • animation-direction
  • animation-timing-function
  • animation-fill-mode
  • animation

خاصیت انیمیشن به شما اجازه می دهد که یک المان را در یک محدوده زمانی مشخص از یک استایل به استایل دیگری تغییر کند. همان طور که اشاره کردیم برای استفاده از خاصیت انیمیشن در css، شما در ابتدا باید یک keyframes برای انیمیشن خود تعریف کنید.

1. معرفی @keyframes در ساخت انیمیشن

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

@keyframes exampl }

  from {background-color: red;}

  to {background-color: yellow;}

در روش دیگر برای مشخص کردن انیمیشن می توان از دستور زیر استفاده کرد:

@keyframes example }

}  0%   background-color: red;}

  25%  {background-color: yellow;}

  50%  {background-color: blue;}

100% {background-color: green;}

 

2. معرفی ویژگی animation-name

اولین گام برای ساخت انیمیشن در CSS، مشخص کردن  نام اختصاصی برای انیمیشن می باشد. این اسن می‌تواند هر نام دلخواهی باشد. برای نمونه، اگه بخواهیم یک المان div رو انیمیشن کنیم، نحوه کدنویسی به صورت زیر خواهد بود:

 div { animation-name: myFirstAnimation; }

 

3. معرفی ویژگی animation-duration

ویژگی animation-duration در CSS3 از سه مقادیر زیر تعریف شده است:

  • مقدار time
  • مقدار initial
  • مقدار inherit

مقدار time درون ویژگی animation-duration

این خاصیت با تعیین کردن یک مقدار عددی بر حسب واحد ثانیه و میلی ثانیه (برای مثال 2s یا ms2) جهت مشخص کردن مدت زمان چرخه اجرا یک انیمیشن مورد استفاده قرار می گیرد.

مقدار initial درون ویژگی animation-duration

با قرار دادن این مقداردهی animation-duration، در واقع مقدار پیش فرض که معادل صفر ثانیه است به مدت زمان چرخه برای یک تگ html اجرا می شود. در حقیقت این مقداردهی مدت زمانی برای اجرای چرخه در انیمیشن لحاظ نمی شود.

مقدار inherit درون ویژگی animation-duration

با قرار دادن این مقداردهی animation-duration، در حقیقت تگ html مربوطه ویژگی های انیمیشن را از والد پدری خود به ارث می برد.

 

 4. معرفی ویژگی animation-delay

این خاصیت به شما اجازه می‌دهد تا مشخص کنید در چه مدت زمانی انیمیشن شروع به اجرا شود. این ویژگی دارای مقدار مثبت مثل 2s تعیین می شود که انیمیشن با تاخیر 2 ثانیه شروع به اجرا می‌کند. اگر به animation-delay مقدار منفی بدهید انیمیشن را یکباره شروع می‌کند اما در ثانیه 2 وارد انیمیشن می‌شود. توجه داشته باشید که مقدار در واحد ثانیه یا میلی ثانیه مشخص می شود. سینتکس CSS این ویژگی به صورت زیر است:

animation-delay: 5s;

 

5. معرفی ویژگی animation-iteration-count

این ویژگی تعداد دفعات اجرا انیمیشن را تعیین می‌کند. مقادیر ممکن عبارتند از:

number: یک مقدار عددی می باشد که تعداد دفعات اجرای انیمیشن را تعیین می کند (حالت پیش فرض 1).

infinite: انیمیشن به صورت نامحدود تکرار می‌شود.

initial: تعداد دفعات اجرا را به مقدار پیش‌فرض تنظیم می‌کند.

inherit: استفاده از مقدار پدر یا والد به ارث می‌برد.

نحوه کدنویسی css به صورت زیر است:

 animation-iteration-count: 2;

 

6. معرفی ویژگی animation-timing-function

این خاصیت، منحنی سرعت یا سرعت انیمیشن در CSS را مشخص می‌کند. شما می‌توانید با استفاده از animation-timing-function زمان‌بندی انیمیشن را با گزینه‌های از پیش تعریف شده نظیر ease, linear, ease-in, ease-out, ease-in-out, initial, inherit انتخاب کنید. البته ساخت انیمشن های با زمانبندی پیشرفته‌تر و سفارشی با کمک cubic-bezier curve تولید کنید. حالت پیش‌فرض این خاصیت، مقدار ease می باشد که با سرعت کم شروع شده و سپس سرعت آن افزایش یافته و در نهایت نیز کاهش می‌یابد.

نحوه کدنویسی css به صورت زیر است:

 animation-timing-function: ease-in-out;

 

7. معرفی ویژگی animation-fill-mode

این خاصیت تعیین می‌کند که استایل‌های انیمیشن، هنگام قبل یا بعد از اجرا انیمیشن می توان مشاهده کرد یا خیر. ممکن است در ابتدا این ویژگی برای شما قابل درک نباشد، اما یک بار که آن را تمرین کنید، برایتان بسیار مفید خواهد بود. مقادیر پیش فرض تعیین شده animation-fill-mode عبارتند از:

  • backwards: با مقداردهی این عنصر قبل از اجرا انیمیشن یا در طول تاخیر در انیمیشن، بر روی استایل‌های keyframe اولیه (0٪) تعریف می‌شود.
  • Forward: پس از اجرا انیمیشن، استایل‌های تعریف شده در keyframe پایانی (100٪) توسط المان حفظ می‌شوند.
  • both: این مقداردهی انیمیشن قوانین را برای هر دو مقدار backwards و Forward رعایت می‌کند و خاصیت های انیمیشن را قبل و بعد از اجرا گسترش می‌دهد.
  • normal (پیش فرض): این مقدار هیچ استایلی بر روی عنصر چه قبل و چه بعد از آن ایجاد نمی‌کند.

نحوه کدنویسی css به صورت زیر است:

animation-fill-mode: forwards;

برای آموزش مقدماتی تا پیشرفته  html و css کلیک کنید