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

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

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

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

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

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

JS метод Element.matches()

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

Метод matches() елемента в JavaScript використовується для перевірки, чи відповідає цей елемент заданому селектору CSS. Цей метод є зручним інструментом для вибірки елементів на сторінці за певними критеріями, що визначаються селектором CSS. Він часто застосовується в обробниках подій, умовних операторах та циклах для фільтрації та маніпулювання елементами DOM.

Синтаксис використання методу matches() є наступним: element.matches(selectors), де element - це посилання на елемент DOM, а selectors - рядок, що містить один або кілька селекторів CSS, розділених комами. Метод повертає true, якщо елемент відповідає заданому селектору, та false в іншому випадку.

Наприклад, припустимо, що ми маємо наступний HTML-код:

<div id="container">
  <p class="text">Параграф 1</p>
  <p class="text highlight">Параграф 2</p>
  <p>Параграф 3</p>
</div>

Ми можемо використати метод matches() для вибірки певних елементів:

const container = document.getElementById('container');
const paragraphs = container.querySelectorAll('p');

paragraphs.forEach(p => {
  if (p.matches('.text')) {
    console.log('Елемент відповідає селектору .text');
  }
  if (p.matches('.text.highlight')) {
    console.log('Елемент відповідає селектору .text.highlight');
  }
});

У цьому прикладі ми спочатку отримуємо посилання на контейнер та всі параграфи всередині нього. Потім ми перебираємо кожен параграф та перевіряємо, чи відповідає він селектору .text або .text.highlight за допомогою методу matches(). Якщо відповідність знайдена, ми виводимо повідомлення в консоль.

Метод matches() також може бути корисним у випадках, коли необхідно виконати певні дії над елементами, що відповідають певному критерію. Наприклад, ми можемо змінити стиль елементів, що відповідають заданому селектору:

const elements = document.querySelectorAll('*');

elements.forEach(element => {
  if (element.matches('a[href^="http"]')) {
    element.style.color = 'green';
  }
});

У цьому прикладі ми отримуємо всі елементи на сторінці за допомогою універсального селектора *. Потім ми перебираємо кожен елемент та перевіряємо, чи відповідає він селектору a[href^="http"], тобто чи є він посиланням, що починається з http. Якщо відповідність знайдена, ми змінюємо колір тексту елемента на зелений.

Метод matches() є потужним інструментом для роботи з DOM та вибірки елементів за певними критеріями. Він забезпечує гнучкість та ефективність у маніпулюванні елементами на сторінці та може бути використаний у різноманітних сценаріях, включаючи обробку подій, валідацію форм, стилізацію елементів та багато іншого.

Порада:

Коли ви працюєте з великою кількістю елементів, використовуйте метод matches() у поєднанні з методами querySelectorAll() та циклами для фільтрації та маніпулювання елементами, що відповідають певним критеріям. Це підвищить ефективність та зрозумілість вашого коду.

Порада:

Для досвідчених програмістів: метод matches() можна використовувати для створення гнучких та потужних функцій, що працюють з DOM. Наприклад, ви можете створити функцію, яка приймає селектор CSS та виконує певні дії над усіма елементами, що відповідають цьому селектору.

Порада:

Пам'ятайте, що метод matches() може бути корисним не лише для перевірки відповідності елемента певному селектору CSS, але й для валідації даних форм, стилізації елементів на основі їх атрибутів та багато іншого. Не обмежуйте себе лише типовими випадками використання.

Синтаксис

matches(selectors)

Параметри

*selectors

Рядок, що містить дійсні CSS селектори для перевірки елемента.

Return

boolean

Повертає значення true, якщо елемент відповідає заданим селекторам. У випадку, якщо елемент не відповідає заданим селекторам, повертається значення false.

Переглядачі

Переглядач

33

34

8

21

15

Переглядач

4.4

33

34

8

Переглядач

-

-

Приклади


У цьому прикладі ми використовуємо метод matches() для перевірки, чи є елемент зображенням або посиланням, і відповідно змінюємо його видимість залежно від стану чекбоксів "Показати зображення" та "Показати посилання". Користувач може взаємодіяти з прикладом, вмикаючи або вимикаючи ці чекбокси, і бачити, як зображення та посилання з'являються або зникають на сторінці.

У цьому прикладі ми використовуємо метод matches() для виділення активного елемента списку навігації. Коли користувач натискає на елемент списку, ми перевіряємо, чи відповідає цей елемент селектору .active. Якщо так, ми видаляємо клас active з усіх інших елементів списку та додаємо його до обраного елемента.

const navItems = document.querySelectorAll('nav ul li');

navItems.forEach(item => {
  item.addEventListener('click', () => {
    // Видалити клас active з усіх елементів списку
    navItems.forEach(item => item.classList.remove('active'));
    
    // Додати клас active до обраного елемента
    if (item.matches('li:not(.active)')) {
      item.classList.add('active');
    }
  });
});

У цьому прикладі ми використовуємо метод matches() для перевірки відповідності кожного елемента заданому селектору. Це дозволяє нам застосувати функцію toggleVisibility() до будь-якого набору елементів, визначеного селектором CSS. Також ми використовуємо метод window.getComputedStyle() для визначення поточного стану видимості елемента, щоб змінити його на протилежний.

function toggleVisibility(selector) {
  const elements = document.querySelectorAll('*'); // Отримати всі елементи на сторінці

  elements.forEach(element => {
    if (element.matches(selector)) { // Перевірити, чи відповідає елемент селектору
      const isVisible = window.getComputedStyle(element).display !== 'none';
      element.style.display = isVisible ? 'none' : 'block'; // Змінити видимість елемента
    }
  });
}

// Приклад використання
toggleVisibility('p.hidden'); // Приховати/показати всі параграфи з класом hidden
toggleVisibility('a[href^="https://"]'); // Приховати/показати всі посилання, що починаються з https://