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

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

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

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

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

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

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

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

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

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

Щоб працювати з mouseenter, використовується метод addEventListener. Наприклад, можна змінити фон кнопки при наведенні курсора:

const button = document.getElementById('myButton');
button.addEventListener('mouseenter', function() {
  button.style.backgroundColor = 'blue';
});

На відміну від події mouseover, mouseenter не має ефекту "вспливання" (bubbling), тобто вона не поширюється до батьківських елементів. Це дозволяє точніше контролювати взаємодію з окремими елементами, зокрема, якщо на сторінці є складна вкладена структура.

Також можна використовувати властивості об'єкта події, такі як event.target, щоб дізнатися, на який елемент зайшов курсор:

element.addEventListener('mouseenter', function(event) {
  console.log('Курсор увійшов на елемент:', event.target);
});

Подія mouseenter зазвичай використовується разом із mouseleave для контролю виходу курсора з елемента. Це дозволяє створювати інтерактивні ефекти, що активуються при наведенні курсора і зникають, коли курсор залишає область елемента.

Порада:

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

Порада:

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

Порада:

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

Синтаксис

element.addEventListener('mouseenter', function(event) {
  // Обробка події
});

Значення

Return

Переглядачі

Переглядач

66

57

11.1

53

16

Переглядач

66

66

57

11.3

Переглядач

15.0.0

1.0

Приклади


Користувач бачить три зображення, розташовані в галереї. Коли курсор миші входить на одне зображення, воно збільшується на 50% за допомогою CSS-трансформації, створюючи ефект "zoom-in". Після того, як курсор залишає зображення, воно повертається до свого початкового розміру. Такий ефект можна використовувати для інтерактивних галерей або карток продуктів на сайті.

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

const card = document.getElementById('card');
card.addEventListener('mouseenter', function() {
  card.style.backgroundColor = '#e0e0e0';
});
card.addEventListener('mouseleave', function() {
  card.style.backgroundColor = 'white';
});

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

const menuItems = document.querySelectorAll('.menu-item');

menuItems.forEach(function(item) {
  item.addEventListener('mouseenter', function() {
    item.classList.add('active');
  });

  item.addEventListener('mouseleave', function() {
    item.classList.remove('active');
  });
});