
- Главная
- Каталог
- Интернет технологии
- Code Ready | Frontend
Code Ready | Frontend
Авторский канал по Frontend разработке.
Статистика канала
Element.matches().
Метод возвращает true или false, проверяя сам элемент (без подъёма по DOM, в отличие от closest()).
Базовый пример:
const el = document.querySelector('.item');
if (el.matches('.item.active')) {
console.log('active item');
}
{}
Пример 1 — фильтрация в делегировании событий:
document.addEventListener('click', (e) => {
if (!(e.target instanceof Element)) return;
if (!e.target.matches('button[data-action]')) return;
console.log('button clicked');
});
{}
Здесь важно: проверяется именно e.target, без поиска родителей.
Пример 2 — комбинация с closest():
document.addEventListener('click', (e) => {
if (!(e.target instanceof Element)) return;
const item = e.target.closest('.list-item');
if (!item || !item.matches('.active')) return;
console.log('active item clicked');
});
{}
closest() находит нужный элемент, matches() уточняет состояние.
Пример 3 — условная логика без лишних переменных:
if (element.matches(':not(.disabled):hover')) {
// логика для активного состояния
}
{}
Пример 4 — работа с псевдоклассами:
if (input.matches(':focus')) {
console.log('input in focus');
}
{}
Поддерживаются обычные CSS-селекторы (включая псевдоклассы). Псевдоэлементы (::before, ::after и т.п.) не применимы.
Пример 5 — проверка перед модификацией:
if (!el.matches('.processed')) {
el.classList.add('processed');
}
{}
Избавляет от дублирующих операций. Важно: если селектор невалидный — будет выброшено исключение, а не возвращён false.
Ещё момент: matches() не ищет родителей или потомков — только текущий элемент. Если нужна проверка вверх по DOM — это задача для closest().
matches() — полезный инструмент для точечной проверки элементов в сложной DOM-логике.
• Создадите отдельный репозиторий для верстки email-шаблонов с помощью MJML;
• Настроите frontend-сборку: сможете писать шаблоны, автоматически компилировать MJML в HTML;
• Реализуете тестовую отправку писем через SMTP, чтобы сразу увидеть результат в почтовом клиенте;
🔊 Читайте подробнее на Habr!
• input[type=radio] используется как источник состояния; • :checked отражает активный элемент; • селекторы связывают состояние с нужным контентом; • label выступает в роли управляющего элемента.Так можно реализовать простые UI-переключатели без дополнительной логики и зависимостей.
position: sticky, а элемент не прилипает.
Во flex и grid элементы по умолчанию имеют align: stretch
(растягиваются по поперечной оси / внутри своей области).
Из-за этого элемент может занять всю доступную высоту и теряет пространство для прилипания.
.layout {
display: flex;
}{}
Решение — убрать растягивание:
.sidebar {
align-self: start;
}{}
Теперь элемент принимает свою реальную высоту и sticky начинает работать как ожидается:
.sidebar {
position: sticky;
top: 0;
align-self: start;
}{}
У sticky должен быть задан top (или другой inset), если проблема у нескольких элементов — используй align-items: start у контейнера.
sticky, а в stretch внутри flex/grid.
const arr = [1, 2, 3];
if (arr.indexOf(2) !== -1) {
console.log("есть");
}
{}
Так писать можно, но это избыточно для простой проверки наличия.
В таких случаях логичнее использовать includes():
const arr = [1, 2, 3];
if (arr.includes(2)) {
console.log("есть");
}
{}
Код читается проще: метод сразу возвращает boolean, без дополнительных сравнений. Но разница между ними не только в удобстве записи.
Есть важный нюанс в сравнении значений:
[NaN].indexOf(NaN); // -1
[NaN].includes(NaN); // true
{}
Почему так: indexOf() использует строгое сравнение (===),
а includes() — алгоритм SameValueZero, который корректно обрабатывает NaN. С обычными значениями это редко имеет значение, но такой кейс полезно знать.
При этом indexOf() никуда не делся — он нужен, когда важен индекс:
const arr = [1, 2, 3];
const idx = arr.indexOf(2);
if (idx !== -1) {
console.log("позиция:", idx);
}
{}
И частая ошибка — использовать результат indexOf() как boolean:
if (arr.indexOf(value)) {
// ...
}
{}
Если элемент находится на позиции 0, условие не сработает, потому что 0 — falsy.
Правильно так:
if (arr.indexOf(value) !== -1) {
// ...
}
{}
includes() предпочтительнее: код чище и семантически точнее, если нужен индекс — используем indexOf().
Отзывы канала
- Добавлен: Сначала новые
- Добавлен: Сначала старые
- Оценка: По убыванию
- Оценка: По возрастанию
Каталог Телеграм-каналов для нативных размещений
Code Ready | Frontend — это Telegam канал в категории «Интернет технологии», который предлагает эффективные форматы для размещения рекламных постов в Телеграмме. Количество подписчиков канала в 22.3K и качественный контент помогают брендам привлекать внимание аудитории и увеличивать охват. Рейтинг канала составляет 12.0, количество отзывов – 1, со средней оценкой 5.0.
Вы можете запустить рекламную кампанию через сервис Telega.in, выбрав удобный формат размещения. Платформа обеспечивает прозрачные условия сотрудничества и предоставляет детальную аналитику. Стоимость размещения составляет 2797.2 ₽, а за 9 выполненных заявок канал зарекомендовал себя как надежный партнер для рекламы в TG. Размещайте интеграции уже сегодня и привлекайте новых клиентов вместе с Telega.in!
Вы снова сможете добавить каналы в корзину из каталога
Комментарий