Веб-страница
23.9K subscribers
1.76K photos
535 videos
1 file
3.96K links
Всё по фронтенду, бэкенду и девопсу в одном месте

Разместить рекламу: @tproger_sales_bot

Правила общения: https://tprg.ru/rules

Другие каналы: @tproger_channels

Сайт: https://tprg.ru/site

Регистрация в перечне РКН: https://tprg.ru/64ai
Download Telegram
Google Chrome теперь поддерживает HTML-элемент <geolocation>

Начиная с Chrome 144, вы можете использовать новый HTML-элемент <geolocation>. Он представляет собой существенное изменение в том, как сайты запрашивают данные о местоположении пользователя — от запросов на разрешение, запускаемых скриптами, к декларативному, ориентированному на действия пользователя интерфейсу. Это позволяет уменьшить количество шаблонного кода, необходимого для обработки состояний разрешений и ошибок, и обеспечивает более сильный сигнал о намерениях пользователя, что помогает избежать вмешательств браузера (например, блокировок).

Подробнее об обновлении в блоге Chrome.
10👍3
React наконец-то решил свою самую большую проблему

Помните недавний сбой у CloudFlare? Небольшая ошибка положила пол интернета. А дело было реактовском useEffect. Да, даже опытные разработчики и крупные компании могут облажаться при использовании этого хука. В команде React сделали выводы и добавили новый хук useEffectEvent, который позволяет избежать неправильной работы системы.

Подробнее о нём в статье.

#react
🗿18👍5😁31
У меня почему-то не открывается. В чем может быть проблема?
😁29
Скрытые функции Google Chrome для разработчика

Chrome Dev Tools — один из самых популярных инструментов среди веб-разработчиков. Однако в неём есть некоторые полезные функции, о которых большинство разработчиков не знает. 

В этой статье вы сможете узнать о пяти основных функциях Chrome DevTools, которые могут вам пригодиться:

https://webformyself.com/skrytye-funkcii-google-chrome-dlya-razrabotchika/

#devtools #инструменты
🔥41
Сложный круговой прогрессбар — простая реализация

Круговые прогрессбары обычно делают на SVG или Canvas. Но оказывается, всё это можно собрать на одном div и одном background-image — если знать, как работают градиенты и современные возможности CSS.

В этом видео вы сможете шаг за шагом собрать круговой индикатор прогресса на чистом CSS: с анимацией, реактивной логикой и динамической сменой цветов — без JavaScript и без SVG.
👍31
⚡️ ​​24 челенжда на знание CSS от freeCodeCamp

На протяжении всех заданий вы будете воссоздавать компоненты и макеты из популярных приложений, таких как GitHub или CodePen, повторяя/проверяя свою подкованность в "ванильном" CSS: https://youtu.be/TzuWIHGFKCQ

➡️ по-моему это лучше чем любой адвент-календарь
Please open Telegram to view this post
VIEW IN TELEGRAM
😁64
PostDad — TUI-клиент для тестирования API, написанный на Rust. Альтернатива Postman, но прямо в терминале.

В свежей версии добавили поддержку WebSocket. Переключение режимов через Ctrl+W, можно подключаться к ws:// и wss:// эндпоинтам, отправлять сообщения в реальном времени и скроллить историю.

Зачем этот проект? Со слов автора:
Postman стал тяжёлым — electron, 500+ МБ RAM, обязательный аккаунт. PostDad — лёгкий TUI, работает в терминале, не требует регистрации. Для тех, кто живёт в консоли и не хочет открывать браузер ради одного GET-запроса.


Что умеет
🔘GET/POST/PUT/DELETE запросы
🔘WebSocket соединения
🔘Работа с headers и body
🔘Всё в TUI без GUI

Альтернативы в этой нише
🔘Bruno — десктоп, open source, хранит коллекции в git-friendly формате
🔘Hoppscotch — браузерный, лёгкий, self-hosted
🔘HTTPie — CLI, но без TUI

PostDad выделяется именно TUI-интерфейсом — интерактивно, но в терминале.

📎 Код на GitHub, установка cargo install PostDad

@prog_tools
Please open Telegram to view this post
VIEW IN TELEGRAM
6👍3
Оно живое: jQuery получил крупное обновление

jQuery 4.0.0 — крупный мажорный релиз с чисткой легаси, улучшениями безопасности и изменениями в поведении, но для большинства проектов апгрейд обещают относительно безболезненным.

Что исправили

🔘Привели порядок фокус‑событий к актуальному W3C: теперь blur → focusout → focus → focusin, jQuery больше не переопределяет нативное поведение (кроме IE).

🔘Починили и доработали AJAX и события: корректная работа с бинарными данными и JSONP‑ошибками, запрет выполнения скриптов при неуспешных HTTP‑ответах, более надёжная обработка фокуса/blur и предотвращение падений при удалении элементов.

🔘Много точечных багфиксов по CSS, селекторам, манипуляции DOM и data‑атрибутам: корректные размеры col, работа contents() у <object>, улучшенные тесты под зум, Bootstrap и др.

Что нового

🔘Поддержка Trusted Types: TrustedHTML можно безопасно передавать в методы манипуляции DOM под CSP require-trusted-types-for.

🔘Большинство асинхронных загрузок скриптов теперь через <script>`‑теги, XHR остаётся только для отдельных случаев (например, с кастомными `headers).

🔘Исходники переведены с AMD на ES‑модули, сборка через Rollup, добавлены именованные экспорты и улучшена совместимость с ESM+CommonJS и современными сборщиками.

🔘Появились .even() и .odd() как замена старым POS‑псевдоклассам :even и :odd.

🔘Slim‑сборка стала ещё компактнее (~19.5 kB gzipped) и теперь без Deferred/Callbacks, с упором на нативные Promises.

Что важного

🔘Список поддерживаемых браузеров серьёзно обновлён: выкинули IE < 11, Edge Legacy, старые iOS, Firefox и Android Browser; IE 11 уберут уже в jQuery 5.0, для олдскула рекомендуют остаться на 3.x.

🔘Массово вырезаны устаревшие API (jQuery.isArray, jQuery.parseJSON, jQuery.trim, jQuery.type, jQuery.now, jQuery.isNumeric, jQuery.isFunction, jQuery.isWindow, jQuery.camelCase, jQuery.nodeName, jQuery.cssNumber, jQuery.cssProps, jQuery.fx.interval и др.) — теперь нужно использовать нативные аналоги (Array.isArray(), JSON.parse(), String.prototype.trim(), Date.now() и т.п.).

🔘Из прототипа jQuery убраны внутренние push, sort, splice; при необходимости их следует вызывать через массивные методы ([].push.call($elems, elem) и т.д.).

🔘За счёт удаления легаси под старые IE и депрекейтед‑API размер ядра уменьшился более чем на 3 kB gzipped.

🔘Для перехода есть upgrade‑гайд и свежий jQuery Migrate, а релиз доступен на CDN и в npm (npm install jquery@4.0.0, плюс slim‑версии на code.jquery.com).

Ну что, пора возвращаться на классику?
Please open Telegram to view this post
VIEW IN TELEGRAM
🔥2014😁10
Разрабы руинят личную жизнь пользователей
😁2317
Найдите ошибку в React-компоненте: Функциональное Карри

В этом выпуске «Найди ошибку» у нас есть простой React компонент-переключатель, который переключается между активным и неактивным состояниями при нажатии. Однако он не работает как ожидается. Сможете ли вы найти ошибку и исправить её?

Переходите по ссылке, чтобы проверить свои навыки, а также посмотреть на один из вариантов решения проблемы:

https://tproger.ru/articles/najdi-oshibku-v-react-komponente-funkcionalnoe-karri/

#react
😁9
Web Almanac 2025: реальные данные о состоянии веба

Web Almanac 2025 — это ежегодный отчёт HTTP Archive о состоянии веба. Он сочетает сырые данные с мнениями экспертов. В издании 16 глав: контент страниц, UX, публикация и дистрибуция.

Данные собраны с 16+ млн сайтов. Идеально для тех, кто хочет понимать тренды веба.
🔥6
Forwarded from Нейроканал
Свёрточная нейросеть на чистом JavaScript с визуализацией — без TensorFlow, без библиотек, работает прямо в браузере.

Рисуешь цифру мышкой — сеть её распознаёт. Всё происходит локально в браузере, ничего никуда не отправляется. Автор говорит, что сейчас нигде не работает и написал это просто чтобы попрактиковаться.

Чтобы понять как CNN работает изнутри — отличная штука. Когда пишешь свёртки, пулинг и backprop руками — понимаешь что там происходит лучше, чем после десяти туториалов по PyTorch. Код в одном файле, можно читать последовательно.

📎 Код на GitHub, рабочая демка на сайте автора, на видео скринкаст для ленивых, чтобы не открывать сайт

@neuro_channel
This media is not supported in your browser
VIEW IN TELEGRAM
Please open Telegram to view this post
VIEW IN TELEGRAM
🔥5👍4
Наклоняем телефон, чтобы ваш UI ожил

Забудьте статичные фолбэки на мобилках. Акселерометр телефона заменяет мышь: наклонил — карточки повернулись в 3D, потряс — элементы «поплыли». Такой подход добавляет интерактивности сайту, а также открывает простор для использования нестандартных механик, созданных специально для мобильных устройств.

Инструкция по реализации в статье.
👎94🤔3
Интервьюер: Напишите код, который отсортирует массив

Я: Array.Sort(массив);

Интервьюер:
😁46🤣11🫡7
GRT Calculator — подбираем размер шрифта на основе золотого сечения

Да, подход не самый обычный. Однако, он позволяет выбрать шрифт, который будет лёгок для чтения и идеально вписываться в дизайн вашего сайта. Достаточно выбрать шрифт, указать его размер и ширину содержимого, а калькулятор покажет, как она будет выглядеть на сайте и подскажет, что стоит поменять, чтобы достичь идеального результата.

Подробнее:

https://grtcalculator.com/

#фронтенд #инструменты
👍52😁2🤔2
Сервисы для тестирования безопасности веб-приложений

Постоянно собирать DevSecOps из опенсорса и разбирать сотни алертов — дорого и долго. Эта статья разбирает несколько готовых сервисов, которые берут большую часть боли на себя и закрывают разные уровни безопасности веб‑приложений:

https://tproger.ru/articles/servisy-dlya-testirovaniya-bezopasnosti-veb-prilozhenij
2
Ещё один совет вообще для всех разработчиков
👍13😁62🤔2🔥1🫡1
OpenAI рассказала, как обслуживает 800 миллионов пользователей ChatGPT на обычном PostgreSQL — больше миллиона запросов в секунду, без кастомных модификаций.

Архитектура: 1 primary инстанс + ~50 read реплик на Azure-инфраструктуре. Latency на p99 — двузначные миллисекунды. Правда, есть нюанс — write-heavy workloads OpenAI вывела в Azure CosmosDB, а в PostgreSQL оставила read-heavy операции.

Что интересно — они не стали городить сложную систему. Вместо этого взяли стандартный PostgreSQL и выжали из него максимум через базовые практики: connection pooling (PgBouncer) для переиспользования соединений вместо создания новых, query optimization для профилирования и переписывания тяжёлых запросов, strategic indexing — индексы ровно там, где нужны.

Для AI-функций используют расширение pgvector — хранят и ищут высокоразмерные векторы (embeddings) для семантического поиска в данных ChatGPT.

База обслуживает данные пользователей, истории разговоров и API-взаимодействия.

➡️ Главный вывод: PostgreSQL действительно масштабируется до экстремальных нагрузок, если правильно настроить. Не нужно сразу бежать за NewSQL или распределёнными системами — сначала стоит выжать всё из проверенных решений.

Инженеры OpenAI подчёркивают: успех в том, что они фокусировались на best practices, а не на переизобретении колеса. Connection pool, индексы, read реплики — это всё есть в документации PostgreSQL. Просто нужно применить грамотно.

Годный пример того, что правильное разделение нагрузки важнее выбора модной БД. PostgreSQL для чтения + CosmosDB для записи — и никакого шардинга одной базы. Простая архитектура побеждает.

📎 OpenAI Blog, Hacker News

@prog_stuff
Please open Telegram to view this post
VIEW IN TELEGRAM
19👍3
🤖 Краулер Meta накрутил счёт за хостинг в 60 раз

Разработчик обнаружил, что бот Meta (meta-externalagent) отправил на его сайт 11 млн запросов за месяц, почти половину от трафика реальных пользователей. Googlebot за то же время сделал лишь 1,1 млн.

Все запросы шли на страницы с серверным рендерингом. Кэширование не помогло: краулеры заходят на уникальные URL один раз и уходят. Счёт Vercel вырос с $30 до $1 933.

Фикс — пара строк в robots.txt:

User-agent: meta-externalagent
Disallow: /


Вопрос к Vercel: почему защита от агрессивного краулинга не включена по умолчанию?
И к Meta: зачем 11 млн запросов — ради превью ссылок?

Вряд ли они мне тут ответят, конечно.
😁8🤯42
Главное, чтобы ещё стул был на колёсиках
🤣598😁6🔥2