WebDev+ | Веб-разработка
8.31K subscribers
506 photos
242 videos
10 files
702 links
Присоединяйтесь к нашему каналу и погрузитесь в мир веб-разработки

Связь: @devmangx
Download Telegram
Разделители в хлебных крошках должны быть в CSS, а не в HTML. Просто используйте псевдоэлемент ::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
👍4
This media is not supported in your browser
VIEW IN TELEGRAM
Мега-новинка в CSS

Теперь можно делать анимации появления и исчезновения элементов.

Знакомься с новым правилом starting-style.

@WebDev_Plus
This media is not supported in your browser
VIEW IN TELEGRAM
Хочешь легко загружать файлы на сайт?

Эта JavaScript-библиотека как раз для этого.

✓ Минимальная настройка
✓ Аккуратные и настраиваемые CSS-стили
✓ Совместима с React, Vue, Angular и jQuery

Установка → npm i filepond

@WebDev_Plus
👍1
Плавно “затухай” текст или картинки.
Одной строкой CSS, без лишних HTML-элементов...

Просто используй mask-image

@WebDev_Plus
👍1
This media is not supported in your browser
VIEW IN TELEGRAM
Искусственная задержка записи, например при отправке формы, может дать пользователю больше уверенности, что изменения действительно применились.

В 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 и т.д.

npm install cally

@WebDev_Plus
Знал, что в JavaScript можно так?

Валидировать формы можно прямо через 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
👍4
This media is not supported in your browser
VIEW IN TELEGRAM
Быстрый совет по TanStack Router:

Вынеси состояние в URL через useSearch.
Страница сразу становится сохраняемой в закладки и удобной для шаринга.

@WebDev_Plus
Сегодня на HackerNews взлетел проект MQuickJS

https://github.com/bellard/mquickjs

MQuickJS — это JavaScript-движок под встраиваемые системы, рассчитанный на ультра-скудные ресурсы. Он умеет компилировать и выполнять JS в условиях, где память на вес золота.

Память жрёт копейки: около 10 kB RAM для запуска, что прям впечатляет. Но есть нюанс — это не полный JS, а подмножество ES5, плюс всё время строгий режим.

@WebDev_Plus
👍21
Сколько бы видосов про server components ты ни смотрел, топовый демо до сих пор тот, который запилила core-команда
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
1
Входящие сообщения WhatsApp для Cloud API, созданного с помощью Next.js

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
🔥3
Оргструктуры, дерево файлов, турнирные сетки — всё на чистом CSS. Без canvas, без SVG, без JavaScript. Только flexbox и псевдоэлементы.

Разбираем по шагам. Начнём с базового дерева слева направо, где пару десятков строк 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
5👍3👎1
Когда я использую <img/> вместо <Image/> в Next js

Next js:

@WebDev_Plus
😁12😭1
This media is not supported in your browser
VIEW IN TELEGRAM
TIL про ListFormat.

Очень удобная и реально мощная штука в JavaScript для форматирования списков так, чтобы они выглядели как естественная человеческая речь.

@WebDev_Plus
This media is not supported in your browser
VIEW IN TELEGRAM
Знал про этот трюк в React?

Если стоят React DevTools, зажимаешь Ctrl + Shift и наводишь курсор на элемент — увидишь название компонента, которому он принадлежит. Удобно, когда быстро хочешь понять, что где рендерится.

@WebDev_Plus
👍3
This media is not supported in your browser
VIEW IN TELEGRAM
На дворе 2026 год.

Для форматирования дат в JavaScript не нужна библиотека.

Просто используйте Intl

@WebDev_Plus