Code Ready | Frontend
22.1K subscribers
1.17K photos
494 videos
17 files
852 links
Авторский канал по Frontend разработке.
Ресурсы, гайды, задачи, шпаргалки.
Информация ежедневно пополняется!

Автор: @energy_it

РКН: https://clck.ru/3NJCKs

Реклама на бирже: https://telega.in/c/code_ready
Download Telegram
👩‍💻 Hover-превью без перерасчёта layout!

В интерфейсах часто нужно показать дополнительную информацию при наведении. Проблема в том, что обычное раскрытие ломает layout и вызывает скачки элементов.

Как работает:
дополнительный слой размещается поверх через position: absolute;

основной контент остаётся на месте и не участвует в перерасчёте;

opacity и transform создают плавное появление;

взаимодействие не влияет на соседние элементы.


Такой подход используют в карточках, таблицах и dashboard-интерфейсах, где важно сохранить стабильность layout.

📣 Code Ready | #фишка
Please open Telegram to view this post
VIEW IN TELEGRAM
Please open Telegram to view this post
VIEW IN TELEGRAM
👍1610🔥9
This media is not supported in your browser
VIEW IN TELEGRAM
👩‍💻 Нужно открыть PDF, не выходя из редактора?

vscode-pdf —
позволяет просматривать PDF-файлы прямо в VS Code: без сторонних приложений и переключений между окнами. Можно быстро открыть документацию, спецификации или инструкции и держать всё в одном рабочем пространстве. Удобно, когда работаешь с проектами, где часто приходится обращаться к PDF.

📣 Code Ready | #vscode
Please open Telegram to view this post
VIEW IN TELEGRAM
🔥17👍10🤝101
Почему прыгает layout при открытии модалки?

Когда появляется вертикальный скролл, браузер добавляет scrollbar — из-за этого меняется ширина viewport и интерфейс смещается. Особенно заметно при модалках и переходах.
body {
overflow: hidden;
}


Убираешь скролл и layout резко сдвигается, потому что исчезает scrollbar.

Есть нативное решение без JS:
html {
scrollbar-gutter: stable;
}


Браузер резервирует место под скролл, даже если его нет (актуально для классического scrollbar):
html {
scrollbar-gutter: stable both-edges;
}


Можно зафиксировать пространство с двух сторон, центрирование остается ровным.

Работает в большинстве современных браузеров и сценариев (при overlay scrollbar эффект может быть незаметен).

🔥 В итоге layout больше не прыгает, интерфейс ощущается стабильнее и аккуратнее.

📣 Code Ready | #совет
Please open Telegram to view this post
VIEW IN TELEGRAM
👍2313🔥11
☕️ Наткнулся на отличную статью на Хабре — создание форм входа и регистрации без единой строчки JavaScript!

В статье:
• Как с помощью HTML5 и CSS3 сделать переключение между формами через :target.
• Стильные анимации и иконки через data-атрибуты.
• Продвинутые стили форм и плавные переходы с использованием CSS3.


🔊 Продолжай читать на Habr!


📣 Code Ready | #статья
Please open Telegram to view this post
VIEW IN TELEGRAM
👍14🔥12🤝113
📂 Напоминалка по работе с числами!

Например, .value у input всегда возвращает строку, из-за чего выражение вроде value + 1 превращается в конкатенацию. А parseInt() может неожиданно обрезать значение.

На картинке — наглядное сравнение способов приведения к числу (parseInt, Number, +) и более удобного варианта через valueAsNumber, который сразу возвращает число.

Сохрани, чтобы не забыть!

📣 Code Ready | #ресурсы
Please open Telegram to view this post
VIEW IN TELEGRAM
👍16🔥8🤝7
Почему includes() часто удобнее, чем indexOf()!

Когда нужно просто проверить, есть ли значение в массиве, многие до сих пор пишут так:
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().

📣 JS Ready | #практика
Please open Telegram to view this post
VIEW IN TELEGRAM
👍197🔥7
This media is not supported in your browser
VIEW IN TELEGRAM
👩‍💻 Нужно быстро связать HTML и CSS?

HTML to CSS autocompletion —
подсказывает CSS-классы и id прямо при работе с HTML. Расширение анализирует стили в проекте и предлагает существующие селекторы, чтобы не допускать опечаток. Удобно при верстке, особенно в больших проектах, где легко запутаться в названиях классов.

📣 Code Ready | #vscode
Please open Telegram to view this post
VIEW IN TELEGRAM
19👍9🔥7🤝2
Почему sticky не работает внутри flex/grid?

Частая ситуация — ставишь 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.

📣 Code Ready | #совет
Please open Telegram to view this post
VIEW IN TELEGRAM
1🤝22👍1312🔥4
This media is not supported in your browser
VIEW IN TELEGRAM
✍️ I Love Coding — краткая шпаргалка по JavaScript!

Это компактный справочник, где собраны основные конструкции языка с примерами кода: переменные, функции, массивы, объекты, условия и работа с данными. Материал подан в сжатом формате, что позволяет быстро вспомнить синтаксис и ключевые концепции без погружения в длинную теорию.

📌 Оставляю ссылочку: ilovecoding.org

📣 Code Ready | #сайт
Please open Telegram to view this post
VIEW IN TELEGRAM
👍16🔥7🤝7
👩‍💻 Переключение контента без JS!

Во многих интерфейсах требуется управлять состоянием: переключать вкладки, фильтры или панели. Базовую логику можно реализовать на CSS.

Как работает:
input[type=radio] используется как источник состояния;

:checked отражает активный элемент;

селекторы связывают состояние с нужным контентом;

label выступает в роли управляющего элемента.


Так можно реализовать простые UI-переключатели без дополнительной логики и зависимостей.

📣 Code Ready | #фишка
Please open Telegram to view this post
VIEW IN TELEGRAM
Please open Telegram to view this post
VIEW IN TELEGRAM
🔥1810👍10
❤️ Нашёл свежую статью на Хабре: «Делаем фронтенд-сборку для верстки HTML-писем на MJML»

В этой статье:
• Создадите отдельный репозиторий для верстки email-шаблонов с помощью MJML;
• Настроите frontend-сборку: сможете писать шаблоны, автоматически компилировать MJML в HTML;
• Реализуете тестовую отправку писем через SMTP, чтобы сразу увидеть результат в почтовом клиенте;


🔊 Читайте подробнее на Habr!


📣 Code Ready | #статья
Please open Telegram to view this post
VIEW IN TELEGRAM
🔥17👍9🤝7
matches(): проверка элемента на соответствие селектору!

Когда работаешь с событиями или обходом 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-логике.

📣 Code Ready | #практика
Please open Telegram to view this post
VIEW IN TELEGRAM
18👍10🤝9
📂 Шпаргалка Flexbox позиционирования!

Flexbox — позволяет контролировать размер, порядок и выравнивание элементов по нескольким осям, распределение свободного места между элементами и многое другое.

Реально полезная тема, поэтому даю вам очень крутую шпаргалку для ее изучения, пользуемся)

📣 Code Ready | #ресурсы
Please open Telegram to view this post
VIEW IN TELEGRAM
👍20🔥11🤝83
This media is not supported in your browser
VIEW IN TELEGRAM
👩‍💻 Атрибут aria-label — доступность без лишней разметки!

Это атрибут для screen reader’ов, который задает текстовое описание элемента для пользователей с нарушениями зрения.

Есть теги и роли, для которых его точно нельзя использовать:
<caption> и роль caption.
<code> и роль code.
<dd> и роль definition.
<dt>, <dfn> и роль term.
<del> и роль deletion.
<em> и роль emphasis.
<ins> и роль insertion.
<mark> и роль mark.
и др.


Когда у элемента должно быть видимое для всех имя, используйте aria-labelledby.

📣 Code Ready | #атрибут
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, рядом с каждой зависимостью отображается доступное обновление. Можно быстро увидеть устаревшие версии и обновить их без лишних проверок, что упрощает поддержку проекта.

📣 Code Ready | #vscode
Please open Telegram to view this post
VIEW IN TELEGRAM
🔥17🤝9👍82
👩‍💻 Карусель с “подглядывающими” карточками без JS!

В интерфейсах важно не просто показать контент, а подтолкнуть пользователя к взаимодействию. Один из приёмов — оставлять часть следующего элемента видимой.

Как работает:
scroll-snap фиксирует карточки при прокрутке;

ширина элемента меньше 100%, поэтому виден соседний блок;

padding контейнера формирует зону “подглядывания”;

:active добавляет быстрый отклик.


Такой паттерн активно используют в мобильных интерфейсах и лендингах, чтобы увеличить вовлечённость.

📣 Code Ready | #фишка
Please open Telegram to view this post
VIEW IN TELEGRAM
Please open Telegram to view this post
VIEW IN TELEGRAM
🔥16👍10🤝92
This media is not supported in your browser
VIEW IN TELEGRAM
😍 QuickRef — компактная шпаргалка по JavaScript!

Это удобный справочник, где собраны ключевые конструкции, методы и синтаксис JS на одной странице. Здесь есть всё необходимое: переменные, функции, операторы, строки, массивы и базовые примеры кода для быстрого ориентирования. Формат максимально сжатый и практичный.

📌 Оставляю ссылочку: quickref.me

📣 Code Ready | #сайт
Please open Telegram to view this post
VIEW IN TELEGRAM
🔥1310👍6🤝6
Как защитить верстку от длинных строк?

Интерфейс может сломаться из-за длинного текста: URL, email, UUID. Он не переносится и раздувает контейнер.

Часто пытаются решать через word-break:
.text {
word-break: break-all;
}


Но это агрессивный вариант, слова ломаются, читаемость страдает.

Есть более аккуратное решение. Браузер будет переносить текст только при необходимости, чтобы избежать переполнения:
.text {
overflow-wrap: anywhere;
}


В обычных условиях слова не трогаются, но при нехватке места могут переноситься.

Если используешь flex/grid — иногда нужен min-width: 0, иначе элемент может не сжиматься.

🔥 Это полезно для чатов, таблиц, карточек, комментариев и любых данных, которые ты не контролируешь.

📣 Code Ready | #совет
Please open Telegram to view this post
VIEW IN TELEGRAM
🔥26👍12🤝114