В интерфейсах часто нужно показать дополнительную информацию при наведении. Проблема в том, что обычное раскрытие ломает
layout и вызывает скачки элементов.Как работает:
• дополнительный слой размещается поверх через position: absolute;
• основной контент остаётся на месте и не участвует в перерасчёте;
• opacity и transform создают плавное появление;
• взаимодействие не влияет на соседние элементы.
Такой подход используют в карточках, таблицах и dashboard-интерфейсах, где важно сохранить стабильность
layout.Please open Telegram to view this post
VIEW IN TELEGRAM
Please open Telegram to view this post
VIEW IN TELEGRAM
👍16❤10🔥9
This media is not supported in your browser
VIEW IN TELEGRAM
vscode-pdf — позволяет просматривать PDF-файлы прямо в VS Code: без сторонних приложений и переключений между окнами. Можно быстро открыть документацию, спецификации или инструкции и держать всё в одном рабочем пространстве. Удобно, когда работаешь с проектами, где часто приходится обращаться к PDF.
Please open Telegram to view this post
VIEW IN TELEGRAM
🔥17👍10🤝10❤1
Почему прыгает layout при открытии модалки?
Когда появляется вертикальный скролл, браузер добавляет
Убираешь скролл и
Есть нативное решение без JS:
Браузер резервирует место под скролл, даже если его нет (актуально для классического
Можно зафиксировать пространство с двух сторон, центрирование остается ровным.
Работает в большинстве современных браузеров и сценариев (при
🔥 В итоге
📣 Code Ready | #совет
Когда появляется вертикальный скролл, браузер добавляет
scrollbar — из-за этого меняется ширина viewport и интерфейс смещается. Особенно заметно при модалках и переходах.body {
overflow: hidden;
}Убираешь скролл и
layout резко сдвигается, потому что исчезает scrollbar.Есть нативное решение без JS:
html {
scrollbar-gutter: stable;
}Браузер резервирует место под скролл, даже если его нет (актуально для классического
scrollbar):html {
scrollbar-gutter: stable both-edges;
}Можно зафиксировать пространство с двух сторон, центрирование остается ровным.
Работает в большинстве современных браузеров и сценариев (при
overlay scrollbar эффект может быть незаметен).layout больше не прыгает, интерфейс ощущается стабильнее и аккуратнее.Please open Telegram to view this post
VIEW IN TELEGRAM
👍23❤13🔥11
В статье:
• Как с помощью HTML5 и CSS3 сделать переключение между формами через :target.
• Стильные анимации и иконки через data-атрибуты.
• Продвинутые стили форм и плавные переходы с использованием CSS3.🔊 Продолжай читать на Habr!
Please open Telegram to view this post
VIEW IN TELEGRAM
👍14🔥12🤝11❤3
Например, .value у input всегда возвращает строку, из-за чего выражение вроде value + 1 превращается в конкатенацию. А parseInt() может неожиданно обрезать значение.
На картинке — наглядное сравнение способов приведения к числу (parseInt, Number, +) и более удобного варианта через valueAsNumber, который сразу возвращает число.
Сохрани, чтобы не забыть!
Please open Telegram to view this post
VIEW IN TELEGRAM
👍16🔥8🤝7
Почему includes() часто удобнее, чем indexOf()!
Когда нужно просто проверить, есть ли значение в массиве, многие до сих пор пишут так:
Так писать можно, но это избыточно для простой проверки наличия.
В таких случаях логичнее использовать
Код читается проще: метод сразу возвращает boolean, без дополнительных сравнений. Но разница между ними не только в удобстве записи.
Есть важный нюанс в сравнении значений:
Почему так:
а
При этом
И частая ошибка — использовать результат
Если элемент находится на позиции 0, условие не сработает, потому что 0 — falsy.
Правильно так:
🔥 Итого: если нужна проверка наличия —
📣 JS Ready | #практика
Когда нужно просто проверить, есть ли значение в массиве, многие до сих пор пишут так:
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().Please open Telegram to view this post
VIEW IN TELEGRAM
👍19❤7🔥7
This media is not supported in your browser
VIEW IN TELEGRAM
HTML to CSS autocompletion — подсказывает CSS-классы и id прямо при работе с HTML. Расширение анализирует стили в проекте и предлагает существующие селекторы, чтобы не допускать опечаток. Удобно при верстке, особенно в больших проектах, где легко запутаться в названиях классов.
Please open Telegram to view this post
VIEW IN TELEGRAM
❤19👍9🔥7🤝2
Почему sticky не работает внутри flex/grid?
Частая ситуация — ставишь
Во flex и grid элементы по умолчанию имеют
(растягиваются по поперечной оси / внутри своей области).
Из-за этого элемент может занять всю доступную высоту и теряет пространство для прилипания.
Решение — убрать растягивание:
Теперь элемент принимает свою реальную высоту и
У
🔥 Часто проблема не в
📣 Code Ready | #совет
Частая ситуация — ставишь
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.Please open Telegram to view this post
VIEW IN TELEGRAM
1🤝22👍13❤12🔥4
This media is not supported in your browser
VIEW IN TELEGRAM
Это компактный справочник, где собраны основные конструкции языка с примерами кода: переменные, функции, массивы, объекты, условия и работа с данными. Материал подан в сжатом формате, что позволяет быстро вспомнить синтаксис и ключевые концепции без погружения в длинную теорию.
Please open Telegram to view this post
VIEW IN TELEGRAM
👍16🔥7🤝7
Во многих интерфейсах требуется управлять состоянием: переключать вкладки, фильтры или панели. Базовую логику можно реализовать на CSS.
Как работает:
• input[type=radio] используется как источник состояния;
• :checked отражает активный элемент;
• селекторы связывают состояние с нужным контентом;
• label выступает в роли управляющего элемента.
Так можно реализовать простые UI-переключатели без дополнительной логики и зависимостей.
Please open Telegram to view this post
VIEW IN TELEGRAM
Please open Telegram to view this post
VIEW IN TELEGRAM
🔥18❤10👍10
В этой статье:
• Создадите отдельный репозиторий для верстки email-шаблонов с помощью MJML;
• Настроите frontend-сборку: сможете писать шаблоны, автоматически компилировать MJML в HTML;
• Реализуете тестовую отправку писем через SMTP, чтобы сразу увидеть результат в почтовом клиенте;🔊 Читайте подробнее на Habr!
Please open Telegram to view this post
VIEW IN TELEGRAM
🔥17👍9🤝7
matches(): проверка элемента на соответствие селектору!
Когда работаешь с событиями или обходом DOM, часто нужно понять — подходит ли конкретный элемент под CSS-селектор. Для этого есть
Метод возвращает true или false, проверяя сам элемент (без подъёма по DOM, в отличие от
Базовый пример:
Пример 1 — фильтрация в делегировании событий:
Здесь важно: проверяется именно
Пример 2 — комбинация с
Пример 3 — условная логика без лишних переменных:
Пример 4 — работа с псевдоклассами:
Поддерживаются обычные CSS-селекторы (включая псевдоклассы). Псевдоэлементы (
Пример 5 — проверка перед модификацией:
Избавляет от дублирующих операций. Важно: если селектор невалидный — будет выброшено исключение, а не возвращён false.
Ещё момент:
🔥
📣 Code Ready | #практика
Когда работаешь с событиями или обходом DOM, часто нужно понять — подходит ли конкретный элемент под CSS-селектор. Для этого есть
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-логике.Please open Telegram to view this post
VIEW IN TELEGRAM
❤18👍10🤝9
Flexbox — позволяет контролировать размер, порядок и выравнивание элементов по нескольким осям, распределение свободного места между элементами и многое другое.
Реально полезная тема, поэтому даю вам очень крутую шпаргалку для ее изучения, пользуемся)
Please open Telegram to view this post
VIEW IN TELEGRAM
👍20🔥11🤝8❤3
This media is not supported in your browser
VIEW IN TELEGRAM
Это атрибут для screen reader’ов, который задает текстовое описание элемента для пользователей с нарушениями зрения.
Есть теги и роли, для которых его точно нельзя использовать:
<caption> и роль caption.
<code> и роль code.
<dd> и роль definition.
<dt>, <dfn> и роль term.
<del> и роль deletion.
<em> и роль emphasis.
<ins> и роль insertion.
<mark> и роль mark.
и др.
Когда у элемента должно быть видимое для всех имя, используйте
aria-labelledby.Please open Telegram to view this post
VIEW IN TELEGRAM
❤18👍12🤝9🔥1
This media is not supported in your browser
VIEW IN TELEGRAM
Version Lens — показывает актуальные версии пакетов прямо в package.json, рядом с каждой зависимостью отображается доступное обновление. Можно быстро увидеть устаревшие версии и обновить их без лишних проверок, что упрощает поддержку проекта.
Please open Telegram to view this post
VIEW IN TELEGRAM
🔥17🤝9👍8❤2
В интерфейсах важно не просто показать контент, а подтолкнуть пользователя к взаимодействию. Один из приёмов — оставлять часть следующего элемента видимой.
Как работает:
• scroll-snap фиксирует карточки при прокрутке;
• ширина элемента меньше 100%, поэтому виден соседний блок;
• padding контейнера формирует зону “подглядывания”;
• :active добавляет быстрый отклик.
Такой паттерн активно используют в мобильных интерфейсах и лендингах, чтобы увеличить вовлечённость.
Please open Telegram to view this post
VIEW IN TELEGRAM
Please open Telegram to view this post
VIEW IN TELEGRAM
🔥16👍10🤝9❤2
This media is not supported in your browser
VIEW IN TELEGRAM
Это удобный справочник, где собраны ключевые конструкции, методы и синтаксис JS на одной странице. Здесь есть всё необходимое: переменные, функции, операторы, строки, массивы и базовые примеры кода для быстрого ориентирования. Формат максимально сжатый и практичный.
Please open Telegram to view this post
VIEW IN TELEGRAM
🔥13❤10👍6🤝6