Наповнення JS розділу

Добридень, Пані та Панове, завдяки вам вдалося зібрати більше 19тис грн з необхідних 15тис на впровадження JS розділу.

JS розділ вже впроваджено - переходимо до його наповнення і почнемо бігти довгий марафон, адже JS має більше 1100 різноманітних методів, властивостей, подій і т.д., які необхідно описати.

Будемо працювати, і вдень, і вночі, щоб орієнтовно взимку закінчити наповнювати JS розділ!

Ви також можете допомогти нам в цьому. Долучайтеся до нашої спільноти в дискорді - ставайте її частиною і допомагайте нашому розвитку.

Також, підтримуйте нас матеріально.

JS властивість Event.animationiteration

Загальний опис

animationiteration — це подія, яка виникає у веб-браузері кожного разу, коли CSS-анімація завершує один повний цикл повторення і починає наступний. Ця подія є частиною стандарту CSS Animations і дозволяє JavaScript реагувати на завершення кожного окремого циклу анімації. Подія animationiteration може бути використана для створення складних інтерактивних ефектів на веб-сторінках, які змінюються в залежності від того, скільки циклів анімації було виконано.

Для використання події animationiteration у JavaScript, необхідно додати обробник подій до елемента, який має CSS-анімацію. Це можна зробити за допомогою методу addEventListener(), який дозволяє виконувати певну функцію кожного разу, коли анімація досягає кінця свого циклу. Наприклад:

const element = document.querySelector('.animated-element');

element.addEventListener('animationiteration', function(event) {
  console.log('Цикл анімації завершено, починається новий цикл.');
});

У цьому прикладі, коли анімація на елементі .animated-element завершує один цикл, у консолі браузера з'являється повідомлення.

Подія animationiteration може бути особливо корисною, коли ви хочете виконувати дії в певний момент під час безперервної анімації. Наприклад, можна змінювати текст, кольори або інші властивості кожного разу, коли анімація повертається до початку. Це може бути корисним для створення інтерактивних ігор або візуалізацій, де поведінка змінюється в залежності від кількості повторень анімації.

Об'єкт події, який передається в обробник події animationiteration, містить інформацію про анімацію, яка викликала подію. Зокрема, властивість animationName містить ім'я анімації, а властивість elapsedTime вказує час, що пройшов від початку анімації, до моменту виклику події. Це дозволяє розробникам створювати більш складні логічні умови в коді:

element.addEventListener('animationiteration', function(event) {
  if (event.animationName === 'bounce') {
    console.log('Анімація "bounce" повторюється.');
  }
});
Порада:

Для налагодження коду, що використовує подію animationiteration, скористайтеся console.log() або іншими методами налагодження, щоб бачити, коли і як часто подія викликається. Це допоможе виявити помилки або неочікувану поведінку.

Порада:

Подія animationiteration не підтримується у всіх старих браузерах, тому обов'язково перевіряйте підтримку браузера перед використанням цієї події в продуктивному коді. Можна використовувати бібліотеки, які забезпечують сумісність із різними браузерами.

Порада:

Якщо ви хочете, щоб анімація змінювала свою поведінку в залежності від поточного циклу, використовуйте властивість animationiteration разом з іншими подіями, такими як animationstart або animationend. Це дозволить вам створювати більш складні та інтерактивні анімації.

Синтаксис

element.addEventListener('animationiteration', function(event) {
  // Ваш код тут
});

Значення

Return

Переглядачі

Переглядач

66

57

11.1

53

16

Переглядач

66

66

57

11.3

Переглядач

15.0.0

1.0

Приклади


У цьому прикладі користувач може взаємодіяти з кнопкою, щоб запускати та зупиняти анімацію. Кожного разу, коли анімація завершує один цикл, подія animationiteration спрацьовує, і на екрані оновлюється кількість циклів, а також змінюється текст на кнопці. Це дозволяє користувачам бачити в реальному часі, як працює подія animationiteration, і як вона може використовуватися для створення інтерактивних елементів на веб-сторінках.

У цьому прикладі лічильник iterationCount збільшується щоразу, коли подія animationiteration спрацьовує. Після п'яти циклів анімація автоматично зупиняється, демонструючи, як можна контролювати поведінку анімації в залежності від кількості повторень.

const animatedBox = document.querySelector('.animated-box');
let iterationCount = 0;

animatedBox.addEventListener('animationiteration', function(event) {
  iterationCount++;
  console.log(`Анімація завершила ${iterationCount} циклів.`);
  if (iterationCount === 5) {
    animatedBox.style.animationPlayState = 'paused'; // Зупиняє анімацію після 5 циклів
    console.log('Анімація зупинена після 5 циклів.');
  }
});

Цей приклад демонструє, як можна змінювати колір елемента після кожного циклу анімації. Після кожного завершення циклу анімації колір змінюється на наступний у масиві кольорів, створюючи ефект динамічного змінення кольорів під час анімації.

const colorBox = document.querySelector('.color-box');
const colors = ['red', 'green', 'blue', 'orange'];
let colorIndex = 0;

colorBox.addEventListener('animationiteration', function(event) {
  colorIndex = (colorIndex + 1) % colors.length;
  colorBox.style.backgroundColor = colors[colorIndex];
  console.log(`Колір змінено на: ${colors[colorIndex]}`);
});