Разделители в хлебных крошках должны быть в CSS, а не в HTML. Просто используйте псевдоэлемент
Селектор
Разметка при этом остается аккуратной и чистой:
Нужны другие разделители? Просто меняете
Для иконок вместо текста можно использовать фоновое изображение:
Этот подход универсальный и подходит для любых горизонтальных списков с разделителями: хлебные крошки, списки тегов, инлайн-метаданные.
@WebDev_Plus
::after.nav > ol > li:not(:last-child)::after {
content: " / ";
color: lightgray;
padding: 0 0.5em;
}Селектор
:not(:last-child) гарантирует, что после последнего элемента разделитель не появится.Разметка при этом остается аккуратной и чистой:
<nav>
<ol>
<li><a href="/">Home</a></li>
<li><a href="/products">Products</a></li>
</ol>
</nav>
Нужны другие разделители? Просто меняете
content:/* Шеврон */
li:not(:last-child)::after {
content: " › ";
}
/* Стрелка */
li:not(:last-child)::after {
content: " → ";
}
/* Вертикальная черта */
li:not(:last-child)::after {
content: " | ";
}
Для иконок вместо текста можно использовать фоновое изображение:
li:not(:last-child)::after {
content: "";
width: 1em;
height: 1em;
background: url("data:image/svg+xml,...") center / contain no-repeat;
}Этот подход универсальный и подходит для любых горизонтальных списков с разделителями: хлебные крошки, списки тегов, инлайн-метаданные.
@WebDev_Plus
👍8
This media is not supported in your browser
VIEW IN TELEGRAM
ИЗИ способ переключить сайт в тёмный режим.
Используется анимация через View Transitions.
Всего 2 строки на JavaScript и немного CSS: https://theme-toggle.rdsx.dev/
@WebDev_Plus
Используется анимация через View Transitions.
Всего 2 строки на JavaScript и немного CSS: https://theme-toggle.rdsx.dev/
@WebDev_Plus
👍4
This media is not supported in your browser
VIEW IN TELEGRAM
Мега-новинка в CSS
Теперь можно делать анимации появления и исчезновения элементов.
Знакомься с новым правилом starting-style.
@WebDev_Plus
Теперь можно делать анимации появления и исчезновения элементов.
Знакомься с новым правилом starting-style.
@WebDev_Plus
This media is not supported in your browser
VIEW IN TELEGRAM
Хочешь легко загружать файлы на сайт?
Эта JavaScript-библиотека как раз для этого.
✓ Минимальная настройка
✓ Аккуратные и настраиваемые CSS-стили
✓ Совместима с React, Vue, Angular и jQuery
Установка →
@WebDev_Plus
Эта JavaScript-библиотека как раз для этого.
✓ Минимальная настройка
✓ Аккуратные и настраиваемые CSS-стили
✓ Совместима с React, Vue, Angular и jQuery
Установка →
npm i filepond@WebDev_Plus
👍1
Плавно “затухай” текст или картинки.
Одной строкой CSS, без лишних HTML-элементов...
Просто используй mask-image
@WebDev_Plus
Одной строкой CSS, без лишних HTML-элементов...
Просто используй mask-image
@WebDev_Plus
👍1
This media is not supported in your browser
VIEW IN TELEGRAM
Искусственная задержка записи, например при отправке формы, может дать пользователю больше уверенности, что изменения действительно применились.
В high-frequency приложениях вроде Linear это начинает раздражать, но для редких действий, типа отправки контактной формы, такой подход ощущается лучше, чем оптимистичное обновление.
Можно использовать Promise.all, чтобы запускать мутацию и задержку параллельно. Тогда пользователь ждет только то, что дольше, а не сумму задержки и времени запроса.
@WebDev_Plus
В high-frequency приложениях вроде Linear это начинает раздражать, но для редких действий, типа отправки контактной формы, такой подход ощущается лучше, чем оптимистичное обновление.
Можно использовать Promise.all, чтобы запускать мутацию и задержку параллельно. Тогда пользователь ждет только то, что дольше, а не сумму задержки и времени запроса.
// A minimum duration of `800ms`
const delay = new Promise((r) => setTimeout(r, 800));
await Promise.all([promise, delay]);
@WebDev_Plus
❤1
This media is not supported in your browser
VIEW IN TELEGRAM
Покажи календарь на сайте или в приложении без лишнего гемора.
Называется Cally, и он годный:
✓ Мультиязычный
✓ Весит всего 9 KB
✓ Кастомизируется через CSS
✓ Работает с React, Angular, Vue и т.д.
→
@WebDev_Plus
Называется Cally, и он годный:
✓ Мультиязычный
✓ Весит всего 9 KB
✓ Кастомизируется через CSS
✓ Работает с React, Angular, Vue и т.д.
→
npm install cally@WebDev_Plus
Знал, что в JavaScript можно так?
Валидировать формы можно прямо через HTML-атрибуты.
А сообщения об ошибках настраивать через setCustomValidity.
Без библиотек и с поддержкой во всех браузерах.
@WebDev_Plus
Валидировать формы можно прямо через HTML-атрибуты.
А сообщения об ошибках настраивать через setCustomValidity.
Без библиотек и с поддержкой во всех браузерах.
@WebDev_Plus
👍2
This media is not supported in your browser
VIEW IN TELEGRAM
Инструмент, который вытаскивает всю информацию о веб-сайте.
✓ Находит проблемы безопасности
✓ Метрики оптимизации и качества
✓ DNS, TXT-записи, SSL, IP-информация и HTTP-заголовки
Ресурс бесплатный и реально полезный:
→ http://web-check.xyz
@WebDev_Plus
✓ Находит проблемы безопасности
✓ Метрики оптимизации и качества
✓ DNS, TXT-записи, SSL, IP-информация и HTTP-заголовки
Ресурс бесплатный и реально полезный:
→ http://web-check.xyz
@WebDev_Plus
👍4
This media is not supported in your browser
VIEW IN TELEGRAM
Быстрый совет по TanStack Router:
Вынеси состояние в URL через useSearch.
Страница сразу становится сохраняемой в закладки и удобной для шаринга.
@WebDev_Plus
Вынеси состояние в URL через useSearch.
Страница сразу становится сохраняемой в закладки и удобной для шаринга.
@WebDev_Plus
Сегодня на HackerNews взлетел проект MQuickJS
https://github.com/bellard/mquickjs
MQuickJS — это JavaScript-движок под встраиваемые системы, рассчитанный на ультра-скудные ресурсы. Он умеет компилировать и выполнять JS в условиях, где память на вес золота.
Память жрёт копейки: около 10 kB RAM для запуска, что прям впечатляет. Но есть нюанс — это не полный JS, а подмножество ES5, плюс всё время строгий режим.
@WebDev_Plus
https://github.com/bellard/mquickjs
MQuickJS — это JavaScript-движок под встраиваемые системы, рассчитанный на ультра-скудные ресурсы. Он умеет компилировать и выполнять JS в условиях, где память на вес золота.
Память жрёт копейки: около 10 kB RAM для запуска, что прям впечатляет. Но есть нюанс — это не полный JS, а подмножество ES5, плюс всё время строгий режим.
@WebDev_Plus
GitHub
GitHub - bellard/mquickjs: Public repository of the Micro QuickJS Javascript Engine
Public repository of the Micro QuickJS Javascript Engine - bellard/mquickjs
👍2❤1
Сколько бы видосов про server components ты ни смотрел, топовый демо до сих пор тот, который запилила core-команда
react:
https://github.com/reactjs/server-components-demo
Там нет вообще никакой интеграции с Next.js, поэтому можно нормально врубиться в сам Flight-протокол.
Очень чётко показана граница server «-» client.
Что тебе реально нужно, чтобы поэкспериментировать:
Если хочешь другой заход для обучения, вот сюда:
https://github.com/reactwg/server-components/discussions/5
Там инженеры из Meta спорили и проектировали RSC. Мне это очень зашло, потому что помогает понять, как принимались решения, а не только как оно работает.
Если после этого всё ещё чешутся руки реально поковырять код, да, я серьёзно, иди вот сюда:
https://github.com/facebook/react/tree/main/packages/react-server-dom-webpack
Там видно, как именно делается сериализация и как кодируются ссылки.
Пожалуйста, обходи стороной рандомные мусорные medium-посты в духе «разберись в RSC за 10 минут». И без этого базового понимания даже не начинай жаловаться, что RSC бесполезны. Мозг же есть, зайди, посиди, разберись.
И в конце уже сравни сам, что именно прячет next-модель от vercel по сравнению с тем, как это устроено у Meta.
@WebDev_Plus
react:
https://github.com/reactjs/server-components-demo
Там нет вообще никакой интеграции с Next.js, поэтому можно нормально врубиться в сам Flight-протокол.
Очень чётко показана граница server «-» client.
Что тебе реально нужно, чтобы поэкспериментировать:
react-server-dom-webpack, createFromFetch, папки Server и Client.Если хочешь другой заход для обучения, вот сюда:
https://github.com/reactwg/server-components/discussions/5
Там инженеры из Meta спорили и проектировали RSC. Мне это очень зашло, потому что помогает понять, как принимались решения, а не только как оно работает.
Если после этого всё ещё чешутся руки реально поковырять код, да, я серьёзно, иди вот сюда:
https://github.com/facebook/react/tree/main/packages/react-server-dom-webpack
Там видно, как именно делается сериализация и как кодируются ссылки.
Пожалуйста, обходи стороной рандомные мусорные medium-посты в духе «разберись в RSC за 10 минут». И без этого базового понимания даже не начинай жаловаться, что RSC бесполезны. Мозг же есть, зайди, посиди, разберись.
И в конце уже сравни сам, что именно прячет next-модель от vercel по сравнению с тем, как это устроено у Meta.
@WebDev_Plus
GitHub
GitHub - reactjs/server-components-demo: Demo app of React Server Components.
Demo app of React Server Components. Contribute to reactjs/server-components-demo development by creating an account on GitHub.
❤1
Входящие сообщения WhatsApp для Cloud API, созданного с помощью Next.js
https://github.com/gokapso/whatsapp-cloud-inbox/
@WebDev_Plus
https://github.com/gokapso/whatsapp-cloud-inbox/
@WebDev_Plus
This media is not supported in your browser
VIEW IN TELEGRAM
Эффект снега для вашего веб-сайта с помощью CSS и JS.
https://codepen.io/jkantner/pen/MYeWWab
@WebDev_Plus
https://codepen.io/jkantner/pen/MYeWWab
@WebDev_Plus
🔥3
Оргструктуры, дерево файлов, турнирные сетки — всё на чистом CSS. Без canvas, без SVG, без JavaScript. Только flexbox и псевдоэлементы.
Разбираем по шагам. Начнём с базового дерева слева направо, где пару десятков строк CSS превращают вот это…(1 photo) во вот это…(2)
HTML — обычные вложенные списки:
Задача: превратить это в дерево с соединительными линиями.
Основная механика — flexbox. Каждый <li> становится flex-контейнером:
Дочерние элементы идут горизонтально, ноды остаются по центру по вертикали.
Первая линия: от родителя к дочерним элементам. Ставим её на <ul>, а не на родительский <li>:
Дальше: линии от каждого ребёнка обратно к родителю. Та же техника, но на <li>:
Проблема: корневой элемент тоже получает линию, хотя родителя у него нет. Чиним через селектор прямого потомка:
Самое тонкое место — вертикальные линии между соседями. Нужны разные высоты:
первый ребёнок — нижняя половина
последний — верхняя половина
все промежуточные — целая линия
Используем ::after:
78 строк CSS — и дерево готово.
Но это только горизонтальный вариант слева направо.
@WebDev_Plus
Разбираем по шагам. Начнём с базового дерева слева направо, где пару десятков строк CSS превращают вот это…(1 photo) во вот это…(2)
HTML — обычные вложенные списки:
<ul class="tree">
<li>
<span>1</span>
<ul>
<li><span>1.1</span></li>
<li><span>1.2</span></li>
</ul>
</li>
</ul>
Задача: превратить это в дерево с соединительными линиями.
Основная механика — flexbox. Каждый <li> становится flex-контейнером:
li {
display: flex;
flex-direction: row;
align-items: center;
}Дочерние элементы идут горизонтально, ноды остаются по центру по вертикали.
Первая линия: от родителя к дочерним элементам. Ставим её на <ul>, а не на родительский <li>:
ul::before {
content: "";
position: absolute;
left: 0;
top: 50%;
border-top: 1px solid;
width: 2vw;
}Дальше: линии от каждого ребёнка обратно к родителю. Та же техника, но на <li>:
li::before {
content: "";
position: absolute;
left: 0;
top: 50%;
border-top: 1px solid;
width: 2vw;
}Проблема: корневой элемент тоже получает линию, хотя родителя у него нет. Чиним через селектор прямого потомка:
.tree > li {
padding-left: 0;
&::before, &::after {
display: none;
}
}Самое тонкое место — вертикальные линии между соседями. Нужны разные высоты:
первый ребёнок — нижняя половина
последний — верхняя половина
все промежуточные — целая линия
Используем ::after:
li::after {
content: "";
position: absolute;
left: 0;
border-left: 1px solid;
}
li:first-of-type::after { height: 50%; bottom: 0; }
li:last-of-type::after { height: 50%; top: 0; }
li:not(:first-of-type):not(:last-of-type)::after {
height: 100%;
}78 строк CSS — и дерево готово.
Но это только горизонтальный вариант слева направо.
@WebDev_Plus
👍5
Обожаю профайлер в Chrome DevTools. Благодаря ему нашёл одну строку, из-за которой функция тупо работала намного медленнее, чем должна. Поменял её — стало в десять раз быстрее, ушло минуты две. Такие лёгкие перф-плюшки реально стоит собирать, окупается на раз.
@WebDev_Plus
@WebDev_Plus
❤5👍3👎1
This media is not supported in your browser
VIEW IN TELEGRAM
TIL про ListFormat.
Очень удобная и реально мощная штука в JavaScript для форматирования списков так, чтобы они выглядели как естественная человеческая речь.
@WebDev_Plus
Очень удобная и реально мощная штука в JavaScript для форматирования списков так, чтобы они выглядели как естественная человеческая речь.
@WebDev_Plus
This media is not supported in your browser
VIEW IN TELEGRAM
Знал про этот трюк в React?
Если стоят React DevTools, зажимаешь Ctrl + Shift и наводишь курсор на элемент — увидишь название компонента, которому он принадлежит. Удобно, когда быстро хочешь понять, что где рендерится.
@WebDev_Plus
Если стоят React DevTools, зажимаешь Ctrl + Shift и наводишь курсор на элемент — увидишь название компонента, которому он принадлежит. Удобно, когда быстро хочешь понять, что где рендерится.
@WebDev_Plus
👍3
This media is not supported in your browser
VIEW IN TELEGRAM
На дворе 2026 год.
Для форматирования дат в JavaScript не нужна библиотека.
Просто используйте
@WebDev_Plus
Для форматирования дат в JavaScript не нужна библиотека.
Просто используйте
Intl@WebDev_Plus