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

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

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

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

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

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

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

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

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

Щоб використовувати подію animationend в JavaScript, потрібно додати обробник подій до елемента, на якому виконується анімація. Це можна зробити за допомогою методу addEventListener(), який дозволяє визначити функцію, що виконується, коли анімація завершується. Наприклад:

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

element.addEventListener('animationend', function(event) {
  console.log('Анімація завершилася на елементі:', event.target);
});

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

Подія animationend може бути корисною в різних ситуаціях, наприклад, коли потрібно очистити DOM після анімації видалення елемента, або коли необхідно запускати наступні анімації в певній послідовності. Подія надає інформацію про властивості анімації, що завершилася, такі як її назва (animationName), тривалість (elapsedTime), та ім'я властивості CSS, яка була анімована.

Щоб обробляти різні анімації на одному елементі, можна використовувати об'єкт події event, який передається до обробника події. Цей об'єкт містить властивість animationName, що дозволяє визначити, яка саме анімація завершилася, і в залежності від цього виконати відповідні дії:

element.addEventListener('animationend', function(event) {
  if (event.animationName === 'fade-out') {
    event.target.style.display = 'none';
  }
});

У цьому прикладі, якщо анімація, що завершилася, має назву fade-out, елемент буде приховано.

Порада:

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

Порада:

Для підвищення продуктивності додайте і видаляйте обробники подій, коли вони більше не потрібні. Це особливо важливо для сторінок з великою кількістю анімацій, щоб уникнути витоків пам'яті та зниження продуктивності.

Порада:

Якщо у вас є анімація, яка повторюється (наприклад, з animation-iteration-count: infinite), подія animationend не виникатиме, доки анімація не завершить усі повторення. Для відстеження кожного циклу анімації використовуйте подію animationiteration.

Синтаксис

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

Значення

Return

Переглядачі

Переглядач

66

57

11.1

53

16

Переглядач

66

66

57

11.3

Переглядач

15.0.0

1.0

Приклади


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

У цьому прикладі після завершення анімації slide-in на елементі .box змінюється стиль бордера. Це може бути корисно для візуального зворотного зв'язку користувачу після виконання анімації.

const box = document.querySelector('.box');

box.addEventListener('animationend', function(event) {
  if (event.animationName === 'slide-in') {
    event.target.style.border = '2px solid green';
    console.log('Анімація завершилася, бордер встановлено.');
  }
});

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

const firstElement = document.querySelector('.first');
const secondElement = document.querySelector('.second');

firstElement.addEventListener('animationend', function(event) {
  if (event.animationName === 'fade-out') {
    secondElement.classList.add('start-next-animation');
    console.log('Перша анімація завершилася, запущено наступну.');
  }
});