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

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

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

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

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

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

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

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

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

timeupdate викликається під час відтворення медіа, коли поточний час змінюється, зазвичай кожні 250 мс, але точний інтервал може залежати від браузера та налаштувань медіа. Для роботи з цією подією потрібно використовувати метод addEventListener, щоб прослуховувати подію для медіаелемента.

const video = document.querySelector('video');
video.addEventListener('timeupdate', (event) => {
  console.log(`Поточний час відтворення: ${video.currentTime}`);
});

У прикладі вище подія timeupdate дозволяє виводити поточний час відтворення кожен раз, коли він змінюється. Можна використовувати властивість currentTime, щоб отримати значення часу, на якому зараз знаходиться медіа.

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

Крім того, важливо розуміти, що timeupdate не генерується постійно під час паузи або зупинки медіа, тому всі оновлення прогресу пов'язані саме з відтворенням мультимедійного елемента. Подія не завжди виникає при кожній зміні кадру, але достатньо часто для оновлення часу з точністю до кількох мілісекунд.

Порада:

Для економії ресурсів не додавайте непотрібних логічних операцій всередині обробника події timeupdate. Це може негативно вплинути на продуктивність, особливо при роботі з великими відео або на старих пристроях.

Порада:

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

Порада:

Використовуйте currentTime, щоб оновлювати інтерфейс користувача, наприклад, відображати час відео в режимі реального часу або оновлювати тайм-код в UI. Це допоможе користувачам орієнтуватися в прогресі відтворення мультимедіа.

Синтаксис

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

Значення

Return

Переглядачі

Переглядач

66

57

11.1

53

16

Переглядач

66

66

57

11.3

Переглядач

15.0.0

1.0

Приклади


Цей приклад реалізує інтерактивний відеопрогравач із кнопками "Відтворити/Пауза" та "Почати спочатку". За допомогою події timeupdate, поточний час відтворення відео оновлюється на прогрес-барі та відображається у вигляді тексту.

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

const video = document.querySelector('video');
const subtitles = [
  { start: 0, end: 5, text: 'Початок відео' },
  { start: 5, end: 10, text: 'Продовження сюжету' }
];

video.addEventListener('timeupdate', () => {
  const currentTime = video.currentTime;
  subtitles.forEach((subtitle) => {
    if (currentTime >= subtitle.start && currentTime <= subtitle.end) {
      console.log(subtitle.text);
    }
  });
});

У цьому прикладі за допомогою події timeupdate можна динамічно оновлювати індикатор прогресу відтворення відео. Прогрес-бар змінюється в реальному часі відповідно до тривалості відтворення мультимедіа.

const video = document.querySelector('video');
const progressBar = document.querySelector('#progress-bar');

video.addEventListener('timeupdate', () => {
  const percentage = (video.currentTime / video.duration) * 100;
  progressBar.style.width = `${percentage}%`;
});