<?xml version="1.0" encoding="UTF-8"?>

<rss version="2.0" xmlns:dc="http://purl.org/dc/elements/1.1/" >

  <channel>
    <title><![CDATA[Все посты подряд / Веб-разработка / Хабр]]></title>
    <link>https://habr.com/ru/hubs/webdev/posts/</link>
    <description><![CDATA[Веб-разработка – делаем веб лучше]]></description>
    <language>ru</language>
    <managingEditor>editor@habr.com</managingEditor>
    <generator>habr.com</generator>
    <pubDate>Sun, 26 Apr 2026 16:47:15 GMT</pubDate>
    
    
      <image>
        <link>https://habr.com/ru/</link>
        <url>https://habrastorage.org/webt/ym/el/wk/ymelwk3zy1gawz4nkejl_-ammtc.png</url>
        <title>Хабр</title>
      </image>
    

    
      
        
    

  

  
  <item>
    <title><![CDATA[Пост @nin-jin — Веб-разработка (+1) — 25.04.2026 16:49]]></title>
    <guid isPermaLink="true">https://habr.com/ru/posts/1027860/</guid>
    <link>https://habr.com/ru/posts/1027860/?utm_campaign=1027860&amp;utm_source=habrahabr&amp;utm_medium=rss</link>
    <description><![CDATA[<p><strong><a href="https://youtu.be/cXPLmrytIiY" rel="noopener noreferrer nofollow">Препарируем Lit и находим родовые травмы</a></strong></p><iframe id="69ecc5d3aeeb010208e02339" src="https://embedd.srv.habr.com/iframe/69ecc5d3aeeb010208e02339" class="embed_video embed__content" allowfullscreen="true"></iframe><p>Задействованы самые современные веб-стандарты, однако:</p><ul><li><p>Заявляется отсутствие VDOM, однако он есть, со всеми вытекающими.</p></li><li><p>Любое исключение капитально ломает весь компонент.</p></li><li><p>Неизбежные конфликты имён компонент всё ломают.</p></li><li><p>Адовые тормоза и потребление памяти из-за привязки к DOM.</p></li><li><p>Тонны бойлерплейта, если нужна кастомизация хотя бы стилей компонент.</p></li></ul><p>Поблагодарить: <a href="https://boosty.to/hyoo" rel="noopener noreferrer nofollow">https://boosty.to/hyoo</a><br>Обсудить: <a href="https://t.me/giper_dev" rel="noopener noreferrer nofollow">https://t.me/giper_dev</a></p> <a href="https://habr.com/ru/posts/1027860/?utm_campaign=1027860&amp;utm_source=habrahabr&amp;utm_medium=rss">Читать дальше &rarr;</a>]]></description>
      
    <pubDate>Sat, 25 Apr 2026 13:49:41 GMT</pubDate>
    <dc:creator><![CDATA[nin-jin]]></dc:creator>
      
      <category><![CDATA[Lit]]></category><category><![CDATA[web-components]]></category>
  </item>
  

	
  

  

  

    

  

  
  <item>
    <title><![CDATA[Пост @rozhnev — SQL (+4) — N/P]]></title>
    <guid isPermaLink="true">https://habr.com/ru/posts/1027118/</guid>
    <link>https://habr.com/ru/posts/1027118/?utm_campaign=1027118&amp;utm_source=habrahabr&amp;utm_medium=rss</link>
    <description><![CDATA[<p>Как я запускал российское зеркало для SQL-песочниц: гибридное облако и блокировки Composer</p><p>Привет, Хабр! Меня зовут Слава, я развиваю SQL-платформы <a href="https://sqltest.online" rel="noopener noreferrer nofollow">sqltest.online</a> и <a href="https://sqlize.online" rel="noopener noreferrer nofollow">sqlize.online</a> для бесплатной тренировки запросов на реальных СУБД (PostgreSQL, Oracle, MariaDB 12.3, MS SQL 2025).</p><p>Зачем понадобилось зеркало?</p><p>От 30% моей аудитории из РФ стали приходить сообщения: «Сайт открывается только через VPN».</p><p>Переносить бэкенд целиком - дорого, сервер завязан на тяжелые СУБД в Docker. Поэтому я выбрал гибридную модель: поднять фронтенд в зоне <code>.ru</code>, оставив бэкенд в Германии.</p><p>Архитектура: Фронт в РФ, мозг в Германии</p><p>Фронтенд: PHP без фреймворков</p><p>Нативный PHP, HTML и JS. Меньше зависимостей - проще деплой. Для RU-зеркала я выбрал <a href="https://sweb.ru/?utm_term=paveavec" rel="noopener noreferrer nofollow">SpaceWeb</a>*, где есть отличные бюджетные тарифы и классная поддержка.</p><pre><code>sqltest-online.ru (SpaceWeb, РФ)
├── PHP (без фреймворков) + HTML/JS
└── Минимум зависимостей
</code></pre><p>Бэкенд: Docker Compose</p><p>Мощный сервер в Германии у <a href="https://contabo.com" rel="noopener noreferrer nofollow">Contabo</a>*, где в контейнерах крутятся MySQL, PostgreSQL, ClickHouse и другие базы. Серьезные СУБД требуют ресурсов, так что всё живет на одной полноценной машине.</p><p>Как они общаются?</p><p>Пользователь отправляет запрос -&gt; браузер делает AJAX-вызов к <code>.ru</code> серверу -&gt; фронт делает HTTP-запрос к бэкенду в Германии (server-to-server) -&gt; бэкенд выполняет SQL и возвращает результат.</p><p><strong>Плюсы схемы:</strong></p><ul><li><p>CORS не нужен: браузер общается только со своим доменом.</p></li><li><p>Бэкенд закрыт: принимает запросы только от white-list IP.</p></li><li><p>Задержка минимальна: интерфейс грузится из РФ, тяжелые запросы идут по быстрому каналу серверов.</p></li></ul><p>Резервного бэкенда нет - проект бесплатный, на второй сервер пока нет бюджета. Если падает Германия, ложится всё.</p><p>Проблемы деплоя: Composer «ушел в отказ»</p><p>С <code>git pull</code> всё прошло гладко, но установка зависимостей зависла намертво.</p><p><strong>Проблема:</strong> Composer не мог достучаться до packagist.org. Просто бесконечный таймаут, вызванный нестабильностью сетевых маршрутов.</p><p><strong>Решение:</strong> Поддержка SpaceWeb не стала отписываться «проблема на вашей стороне», а сразу дала адрес HTTP-прокси.</p><p>Дело одной команды:</p><pre><code class="bash">export HTTPS_PROXY=http://proxy.host:port
composer install
</code></pre><p><em>(Для Windows: <code>set HTTPS_PROXY=...</code>)</em></p><p><strong>Мораль:</strong> При деплое на российские площадки проверяйте доступность packagist.org (<code>curl -v https://packagist.org</code>). Если висит - просите прокси у хостера, не тратьте время на Composer.</p><p>Итоги</p><p>Зеркало <a href="https://sqltest-online.ru" rel="noopener noreferrer nofollow">sqltest-online.ru</a> работает. Гибридная схема спасает: пользователи получают быстрый интерфейс без VPN, а запросы улетают на проверенный бэкенд.</p><p>Я верю, что образование должно быть доступным. Если для практики SQL нужно включать VPN и ждать по 10 секунд - человек не будет учиться. Зеркало <code>.ru</code> - мой способ сказать: «Продолжайте практиковаться».</p><p>А как вы деплоите зависимости на RU-площадки? Используете прокси, зеркала или есть решения изящнее?</p><p><em>* P.S. Ссылки на SpaceWeb и Contabo в статье - реферальные. Сервисами пользуюсь сам и смело рекомендую, а бонусы пойдут на оплату серверов проекта.</em></p> <a href="https://habr.com/ru/posts/1027118/?utm_campaign=1027118&amp;utm_source=habrahabr&amp;utm_medium=rss">Читать дальше &rarr;</a>]]></description>
      
    <pubDate>Fri, 24 Apr 2026 07:01:10 GMT</pubDate>
    <dc:creator><![CDATA[rozhnev]]></dc:creator>
      
      <category><![CDATA[PHP]]></category><category><![CDATA[Docker]]></category><category><![CDATA[Composer]]></category><category><![CDATA[Хостинг]]></category><category><![CDATA[Пет-проект]]></category><category><![CDATA[Личный опыт]]></category>
  </item>
  

	
  

  

  

    

  

  
  <item>
    <title><![CDATA[Пост @fil_and — Браузеры (+4) — 17.04.2026 17:03]]></title>
    <guid isPermaLink="true">https://habr.com/ru/posts/1024722/</guid>
    <link>https://habr.com/ru/posts/1024722/?utm_campaign=1024722&amp;utm_source=habrahabr&amp;utm_medium=rss</link>
    <description><![CDATA[<p>Подборка залипательнейших прикольных интернет-сервисов. Собирал для вас годами, чтобы вы могли покликать и поухмыляться. </p><p><a href="https://pointerpointer.com/" rel="noopener noreferrer nofollow">https://pointerpointer.com/</a> — PointerPointer: сервис находит фото, где человек указывает пальцем прямо на ваш курсор.</p><p><a href="https://hackertyper.net/" rel="noopener noreferrer nofollow">https://hackertyper.net/</a> — HackerTyper: почувствуйте себя кинохакером — просто быстро жмите любые клавиши.</p><p><a href="https://www.window-swap.com/" rel="noopener noreferrer nofollow">https://www.window-swap.com/</a> — WindowSwap: видео из случайных окон реальных людей по всему миру.</p><p><a href="https://astronaut.io/" rel="noopener noreferrer nofollow">https://astronaut.io/</a> — <a href="http://Astronaut.io" rel="noopener noreferrer nofollow">Astronaut.io</a>: случайные видео с YouTube с нулевым количеством просмотров и странными названиями.</p><p><a href="https://neal.fun/wonders-of-street-view/" rel="noopener noreferrer nofollow">https://neal.fun/wonders-of-street-view/</a> — Wonders of Street View: самые необычные и прикольные места, найденные на Google Картах.</p><p><a href="https://radio.garden/" rel="noopener noreferrer nofollow">https://radio.garden/</a> — Radio Garden: глобус, на котором можно слушать прямой эфир радиостанций из любой точки планеты.</p><p><a href="https://radiooooo.com/" rel="noopener noreferrer nofollow">https://radiooooo.com/</a> — Radiooooo: музыкальная машина времени — выбираете страну и десятилетие.</p><p><a href="https://earth.fm/" rel="noopener noreferrer nofollow">https://earth.fm/</a> — <a href="http://Earth.fm" rel="noopener noreferrer nofollow">Earth.fm</a>: интерактивная карта с записями звуков природы со всего мира.</p><p><a href="https://floor796.com/" rel="noopener noreferrer nofollow">https://floor796.com/</a> — Floor796: огромная живая анимация с сотнями персонажей поп-культуры.</p><p><a href="https://www.windows93.net/" rel="noopener noreferrer nofollow">https://www.windows93.net/</a> — Windows 93: полноценная (и очень странная) операционная система прямо в вашем браузере.</p><p><a href="http://www.excelworld.ru/" rel="noopener noreferrer nofollow">http://www.excelworld.ru/</a> — ExcelWorld: всё о работе в Excel и даже чуть больше.</p><p><a href="https://www.makewordart.com/" rel="noopener noreferrer nofollow">https://www.makewordart.com/</a> — MakeWordArt: тот самый дизайн надписей из Microsoft Word 2000.</p><p><a href="https://90s.myretrotvs.com/" rel="noopener noreferrer nofollow">https://90s.myretrotvs.com/</a> — 90s TV: симулятор телевизора из 90-х с рекламой и передачами того времени.</p><p><a href="https://archive.org/details/softwarelibrary_msdos_games" rel="noopener noreferrer nofollow">https://archive.org/details/softwarelibrary_msdos_games</a> — MS-DOS Games: огромный архив старых игр, в которые можно играть онлайн.</p><p><a href="https://webamp.org/" rel="noopener noreferrer nofollow">https://webamp.org/</a> — Webamp: легендарный плеер Winamp, работающий в браузере.</p><p><a href="https://poolsuite.net/" rel="noopener noreferrer nofollow">https://poolsuite.net/</a> — Poolsuite: эстетика 80-х, ретро-радио и летний вайб.</p><p><a href="http://savethesounds.info/" rel="noopener noreferrer nofollow">http://savethesounds.info/</a> — Save The Sounds: музей исчезающих звуков (от кассет до старых модемов).</p><p><a href="https://zzz.zoomquilt2.com/" rel="noopener noreferrer nofollow">https://zzz.zoomquilt2.com/</a> — Zoomquilt 2: бесконечное сюрреалистичное изображение, в которое можно «влипать» вечно.</p><p><a href="https://stars.chromeexperiments.com/" rel="noopener noreferrer nofollow">https://stars.chromeexperiments.com/</a> — 100,000 Stars: визуализация ближайших к нам звезд в 3D.</p><p><a href="https://htwins.net/scale2/" rel="noopener noreferrer nofollow">https://htwins.net/scale2/</a> — Scale of the Universe: интерактивная шкала масштабов Вселенной — от атомов до галактик.</p><p><a href="https://pastvu.com/" rel="noopener noreferrer nofollow">https://pastvu.com/</a> — PastVu: архив исторических фотографий с привязкой к месту на карте.</p><p><a href="https://pudding.cool/" rel="noopener noreferrer nofollow">https://pudding.cool/</a> — The Pudding: визуализация плотности населения Земли в виде 3D-гор.</p><p><a href="https://trismegistus.tech/apps/begit/index.html" rel="noopener noreferrer nofollow">https://trismegistus.tech/apps/begit/index.html</a> — Бегит, Анжуманя: забавный чеклист для тренировок (пресс качать, анжуманя).</p><p><a href="https://www.koalastothemax.com/" rel="noopener noreferrer nofollow">https://www.koalastothemax.com/</a> — Koalas to the Max: расщепляйте круги, пока не увидите картинку.</p><p><a href="https://www.incredibox.com/demo/" rel="noopener noreferrer nofollow">https://www.incredibox.com/demo/</a> — Incredibox: создавайте крутой битбокс с помощью стильных персонажей.</p><p>Записал видео, как показываю эти сервисы:</p><iframe id="69e23c6e80609702592c70c6" src="https://embedd.srv.habr.com/iframe/69e23c6e80609702592c70c6" class="embed_video embed__content" allowfullscreen="true"></iframe> <a href="https://habr.com/ru/posts/1024722/?utm_campaign=1024722&amp;utm_source=habrahabr&amp;utm_medium=rss">Читать дальше &rarr;</a>]]></description>
      
    <pubDate>Fri, 17 Apr 2026 14:03:34 GMT</pubDate>
    <dc:creator><![CDATA[fil_and]]></dc:creator>
      
      <category><![CDATA[интернет-сервисы]]></category><category><![CDATA[интересное]]></category><category><![CDATA[игры и игровые приставки]]></category>
  </item>
  

	
  

  

  

    

  

  
  <item>
    <title><![CDATA[Пост @iamshpeht — Развитие стартапа (+1) — 08.04.2026 11:13]]></title>
    <guid isPermaLink="true">https://habr.com/ru/posts/1020690/</guid>
    <link>https://habr.com/ru/posts/1020690/?utm_campaign=1020690&amp;utm_source=habrahabr&amp;utm_medium=rss</link>
    <description><![CDATA[<p><em>Не особо интересный пост. </em><br><br>Я все еще считаю, что стартап — это весело 🐙</p><p><br>Наша разработка hardware продукта напрямую связана с софтом. В нашем случае <strong>умный датчик качества воздуха Atmy</strong>, становится по настоящему “умным” в связке с целой экосистемой в виде интеграций ML моделей, системы подтверждения качества данных Atmy Trust Rating (хочу об этом написать отдельно позже), токенизации, веб-сайта и приложения для управления устройством. <br><br>Всю эту архитектуру приходиться менять практически в real-time. Поймал себя на ощущении, что уже немного вышел в пограничное состояние. Дни заканчиваются не вечером, а как-то плавно перетекают в следующий день. Иногда в голове уже слышен характерный «треск» старого жесткого диска. Но самое странное — мне это нравится. Потому что именно сейчас добрался до тех вещей, которые годами откладывал «на потом, когда будут ресурсы».</p><p><strong>Спойлер 👀: ресурсов никогда не будет хватать.&nbsp;</strong></p><p><br>Приведу вам пример того, как мы работаем над платформой <a href="http://atmy.ai" rel="noopener noreferrer nofollow">atmy.ai<br><br></a>Наша платформа раскладывается на три уровня:</p><p>↖️User product <strong>← сейчас мы здесь</strong></p><p>Какой воздух вокруг меня?</p><p>↖️Device management</p><p>Как живут мои станции?</p><p>↖️Data intelligence</p><p>Дай аналитику, API, выгрузки и объясни, что вообще происходит.</p><p><strong><br>Объем большой. Мы реализуем функционал, которого еще не существует, поэтому выбрали работу по уровням и с быстрым тестированием:</strong></p><p><strong>накрутить идеи на максимум → быстро обкатать → выкинуть лишнее → остальное в прод и допиливать API</strong></p><p>На практике это выглядит так: <br><br>появилась идея → накидываем проект в Figma (важно визуальное, так как делаем для людей) → дорабатываем за пару дней MPV через Cursor → тестируем → а далее либо удаляем без сожалений / либо сразу на git программистам.</p><p>Из того, что уже долетело до продакшна:<br></p><figure class="full-width "><img src="https://habrastorage.org/getpro/habr/upload_files/c42/fea/dc5/c42feadc58335e80c2fee00d19cc7ce7.png" width="3246" height="1954"></figure><p><strong>— Atmy Data Hub</strong></p><p>Место, где наконец появилась нормальная аналитика по стране и миру. Скачивание графика по клику или скачать готовый csv файл. Графики, которых мне самому отчаянно не хватало в начале пути, когда заинтересовался экологией в своем городе.</p><p><strong>— Режим “Мониторинг”</strong></p><p>Внутри я его называю «око Саурона». По клику кнопки “Мониторинг” переходишь в этот режим сразу с карты, где “сейчас” находишься — и просто наблюдаешь за динамикой изменения воздуха в реальном времени. Все элементы в большем масштабе для удобного считывания с расстояния, обновление происходит практически real-time.</p><p><br>Есть ещё несколько фич, но их судьба пока под вопросом. <br><br>Например:</p><p>Мы тестируем <strong>гибридный режим (CAMS+AirMap Local)</strong> отображения глобального слоя pm2.5 CAMS совмещенный с локальными данными с земли, чтобы достичь максимальной актуальности данных. Здесь много математики и это тоже очень увлекательно. <br><br>И это всё — только первый слой.</p><p>В общем, путь, как обычно, не самый простой. Но, кажется, именно так и должно быть в любом стартапе<br><br><strong>Больше картинок и общения в нашем маленьком чате разработки телеграм: <a href="https://t.me/atmyhub" rel="noopener noreferrer nofollow">https://t.me/atmyhub</a></strong></p> <a href="https://habr.com/ru/posts/1020690/?utm_campaign=1020690&amp;utm_source=habrahabr&amp;utm_medium=rss">Читать дальше &rarr;</a>]]></description>
      
    <pubDate>Wed, 08 Apr 2026 08:13:42 GMT</pubDate>
    <dc:creator><![CDATA[iamshpeht]]></dc:creator>
      
      <category><![CDATA[atmy]]></category><category><![CDATA[стартап]]></category><category><![CDATA[стартапы]]></category><category><![CDATA[веб-дизайн]]></category><category><![CDATA[web]]></category><category><![CDATA[веб-сайт]]></category>
  </item>
  

	
  

  

  

    

  

  
  <item>
    <title><![CDATA[Пост @denis-19 — Искусственный интеллект (+3) — 06.04.2026 08:07]]></title>
    <guid isPermaLink="true">https://habr.com/ru/posts/1019662/</guid>
    <link>https://habr.com/ru/posts/1019662/?utm_campaign=1019662&amp;utm_source=habrahabr&amp;utm_medium=rss</link>
    <description><![CDATA[<p>Представлен открытый проект <a href="https://github.com/VoltAgent/awesome-design-md" rel="noopener noreferrer nofollow">Awesome DESIGN.md</a> для обучения ИИ на основе дизайнов 30 топовых IT-компаний, включая полный разбор дизайнов каждой компании: например Airbnb, Pinterest, Revolut, Uber, Spotify, SpaceX, NVIDIA и Apple. В итоге получается набор данных, в том числе паттерны, шрифты, цвета, кнопки, отступы и вообще всё, что формирует стиль. </p><figure class="full-width "><img src="https://habrastorage.org/getpro/habr/upload_files/434/3c8/5cf/4343c85cf6fa08061394774aa9fc12ed.png" width="700" height="601"></figure> <a href="https://habr.com/ru/posts/1019662/?utm_campaign=1019662&amp;utm_source=habrahabr&amp;utm_medium=rss">Читать дальше &rarr;</a>]]></description>
      
    <pubDate>Mon, 06 Apr 2026 05:07:09 GMT</pubDate>
    <dc:creator><![CDATA[denis-19]]></dc:creator>
      
      <category><![CDATA[Awesome DESIGN.md]]></category>
  </item>
  

	
  

  

  

    

  

  
  <item>
    <title><![CDATA[Пост @Dalee_group — Блог компании Далее (+2) — 03.04.2026 17:18]]></title>
    <guid isPermaLink="true">https://habr.com/ru/companies/dalee_group/posts/1019046/</guid>
    <link>https://habr.com/ru/companies/dalee_group/posts/1019046/?utm_campaign=1019046&amp;utm_source=habrahabr&amp;utm_medium=rss</link>
    <description><![CDATA[<figure class="full-width "><img src="https://habrastorage.org/getpro/habr/upload_files/dfb/e3a/331/dfbe3a33169c15daa7948f43ddddd6c8.png" width="1200" height="600"></figure><p>Вам пишет рекрутер из известной компании. Вакансия — мечта. Собеседование — завтра. Нужно только установить «утилиту для тестового задания». А дальше — украденные учётки, шантаж и ощущение, что мир сошёл с ума.<br><br>HRD Далее Ася Маркевич выступила экспертом подкаста от Департамента разработки «Как не стать жертвой фейковых рекрутеров». <br><br>Смотрите на Rutube  <a href="https://rutube.ru/video/8888fe21f49e6c50f1e78816fde1216c/" rel="noopener noreferrer nofollow">https://rutube.ru/video/8888fe21f49e6c50f1e78816fde1216c/</a> </p> <a href="https://habr.com/ru/posts/1019046/?utm_campaign=1019046&amp;utm_source=habrahabr&amp;utm_medium=rss">Читать дальше &rarr;</a>]]></description>
      
    <pubDate>Fri, 03 Apr 2026 14:18:28 GMT</pubDate>
    <dc:creator><![CDATA[Dalee_group (Далее)]]></dc:creator>
      
      <category><![CDATA[рекрутинг]]></category><category><![CDATA[фейки]]></category><category><![CDATA[фрод]]></category><category><![CDATA[hr]]></category>
  </item>
  

	
  

  

  

    

  

  
  <item>
    <title><![CDATA[Пост @erbanovanastasia — Блог компании Selectel (+4) — N/P]]></title>
    <guid isPermaLink="true">https://habr.com/ru/companies/selectel/posts/1018970/</guid>
    <link>https://habr.com/ru/companies/selectel/posts/1018970/?utm_campaign=1018970&amp;utm_source=habrahabr&amp;utm_medium=rss</link>
    <description><![CDATA[<p><strong>Вторая часть курса по JavaScript уже доступна</strong> 💻</p><figure class="full-width "><img src="https://habrastorage.org/getpro/habr/upload_files/77c/0c0/cac/77c0c0cacc0c6e8c0457a3455027e578.png" width="1999" height="664"></figure><p>Привет, Хабр! Массивы, объекты, операторы, DOM — если вы еще не работаете с ними, проходите бесплатный курс «<a href="https://study.selectel.ru/javascript_course/?utm_source=habr.com&amp;utm_medium=referral&amp;utm_campaign=course_post_javascript_030425" rel="noopener noreferrer nofollow">Первые шаги в JavaScript</a>». Во время обучения вы освоите базовый синтаксис и конструкции языка, а затем напишете пет-проект. &nbsp;</p><p>Вторая часть состоит из пяти модулей. После курса вы сможете:</p><ul><li><p>изучать более продвинутые фреймворки и библиотеки;</p></li><li><p>понимать архитектуру простых веб-приложений;</p></li><li><p>писать скрипты, управлять DOM и изменять интерфейс веб-страниц.</p></li></ul><p>Осваивайте практические навыки с помощью IT-инфраструктуры Selectel — промокод на бесплатный доступ уже ждет на курсе. После успешного прохождения финального теста пришлем именной сертификат.</p><p><strong><a href="https://study.selectel.ru/javascript_course/?utm_source=habr.com&amp;utm_medium=referral&amp;utm_campaign=course_post_javascript_030425" rel="noopener noreferrer nofollow">Начните обучение прямо сейчас →</a></strong></p> <a href="https://habr.com/ru/posts/1018970/?utm_campaign=1018970&amp;utm_source=habrahabr&amp;utm_medium=rss">Читать дальше &rarr;</a>]]></description>
      
    <pubDate>Fri, 03 Apr 2026 12:53:03 GMT</pubDate>
    <dc:creator><![CDATA[erbanovanastasia (Selectel)]]></dc:creator>
      
      <category><![CDATA[selectel]]></category><category><![CDATA[курс]]></category><category><![CDATA[обучение]]></category><category><![CDATA[разработка]]></category><category><![CDATA[js]]></category><category><![CDATA[javascript]]></category><category><![CDATA[бесплатные курсы]]></category>
  </item>
  

	
  

  

  

    

  

  
  <item>
    <title><![CDATA[Пост @Viktoria_Arturovna — Веб-разработка (+1) — 02.04.2026 14:48]]></title>
    <guid isPermaLink="true">https://habr.com/ru/posts/1018474/</guid>
    <link>https://habr.com/ru/posts/1018474/?utm_campaign=1018474&amp;utm_source=habrahabr&amp;utm_medium=rss</link>
    <description><![CDATA[<p>Будет слишком по девчачьи сказать, что я плакала из-за код ревью? </p><p>Это было года три или&nbsp;четыре назад, когда я ещё не&nbsp;нашла общий язык со своим новым тех.лидом. Тогда много всего накопилось, и каждый новый комментарий, хоть он и&nbsp;был очень корректным, ощущался как&nbsp;еще один удар сверху. Помню&nbsp;было что‑то из&nbsp;серии: «Тут надо изменить нейминг».</p><p>Ничего такого, вроде все ок. Но я смотрела на него и зависла в моменте: а что именно не так то? Есть какие то правила в новой команде, о которых я еще не знаю? Нужно переименовать только эту переменную или мне нужно пройтись по всему файлу?</p><p>Начинаешь писать ответ, ждешь уточнения, потом опять ответ... В какой то момент я просто закрыла ноут и разревелась. Я уже находилась в состоянии нервного клубка и такие комментарии добивали больше, чем любой жёсткий разнос. </p><p>Но самое забавное, спустя время я пересмотрела старые ПР и поняла, что мой техлид был максимально корректным и без токсичности. Просто я уже была на грани выгорания и каждый комментарий превращался в испытание. </p><p>Мне захотелось поделиться своими мыслями на тему код-ревью, о том как формулировки влияют на скорость работы и состояния людей:</p><blockquote><p><a href="https://habr.com/ru/companies/alfa/articles/1017452/" rel="noopener noreferrer nofollow">Ссылка на статью</a></p></blockquote><p>Если хоть раз сидел и думал: «что от меня тут вообще хотят?» — ты точно поймёшь&nbsp;:)</p> <a href="https://habr.com/ru/posts/1018474/?utm_campaign=1018474&amp;utm_source=habrahabr&amp;utm_medium=rss">Читать дальше &rarr;</a>]]></description>
      
    <pubDate>Thu, 02 Apr 2026 11:48:40 GMT</pubDate>
    <dc:creator><![CDATA[Viktoria_Arturovna]]></dc:creator>
      
      <category><![CDATA[code review]]></category>
  </item>
  

	
  

  

  

    

  

  
  <item>
    <title><![CDATA[Пост @VitBurk — Веб-разработка (+1) — N/P]]></title>
    <guid isPermaLink="true">https://habr.com/ru/posts/1015422/</guid>
    <link>https://habr.com/ru/posts/1015422/?utm_campaign=1015422&amp;utm_source=habrahabr&amp;utm_medium=rss</link>
    <description><![CDATA[<p><strong>Какой user-side подход выбрать?</strong></p><p>Может многие и не задавались вопросом, но я думаю это интересная тема, которую можно прояснить.</p><p>Допустим, мы пилим какой-нибудь интересный сервис. Ну вот написали мы бэкенд, а как пользователь будет с ним взаимодействовать? По моему мнению сейчас есть несколько основных вариантов: веб-приложение, мобильное прилижение и телеграм-бот. Конечно, если есть много лишних рук, можно написать всё и сразу, но это не мой варик.</p><p>В моём случае каждая строчка кода дорога. Работаю я в одиночку.</p><p>Сейчас я разрабатываю сервис по изучению иностранных слов и на основе моего опыта хочу сделать некое сравнение этих подходов.</p><p><strong>Телеграм-бот</strong></p><p>Вообще начал я user-side телеграм-ботом. Поначалу это, конечно, может, и казалось достаточным, но всё-таки для какого-либо функционала простого телеграм-бота не хватает.</p><p>Да и ещё в добавок в Russian Federation начали блокировать тг, поэтому пользоваться им приходится с костылями, а бот перестал стабильно работать.</p><p>Вывод: тг-бот - для простого функционала, но довольно нестабилен и ограничен функционал</p><p>Хотя, есть mini-app, но в их подробности я не вдавался.</p><p><strong>Веб-приложение</strong></p><p>Следующий очень популярный вариант - веб-приложение. Этот вариант намного более гибок. Но по моему мнению всё же не максимально стабилен, так как его работа зависит от состояния браузера. Но у этого варианта есть огромное преимущество: он работает на всех устройствах, на которых можно открыть веб-сайт. Это, так сказать, униварсальный вариант.</p><p>Но есть проблема. Допустим, человек пользуется чем-то на постоянной основе и хочет максимально быструю и адаптированную работу. Он будет постоянно заходить в браузер и копаться во вкладках? Или лучше тогда выбрать мобильное приложение?</p><p><strong>Мобильное приложение</strong></p><p>Наверное самый сложный и трудозатратный, но по моему мнению в нынешнее время самый перспективный вариант. Да, по сравнению с веб-собратом работать оно будет не везде, а только на мобилке, при том на определённой (IOS или Android).</p><p>Но при этом мобильное приложение даёт реализовать максимально удобное и оптимизированное управление, потому что почти всё можно настроить под свой продукт.</p><p><strong>Небольшая сводка</strong></p><p>Для чего бот: для простого функционала. Можно использовать как небольшое дополнение к какой-либо инфраструктуре. Этот подход наименее трудозатратен.</p><p>Для чего веб-приложения: для продуктов, где нужна кроссплатформенность и довольно широкая кастомизация. Подход не сильно трудозатратный.</p><p>Для чего мобильные приложения: для продуктов где важна максимальная быстрота и удобство и наилучшии возможности кастомизации. По моему мнению наиболее подходит для каких-то интересных и уникальных сервисов. Это самый трудозатратный подход из перечисленный, но в некоторых случаях он более чем себя оправдывает.</p><p>Что кому разрабатывать в первую очередь зависит от самого проекта, универсального варианта здесь нет по моему мнению.</p><p>PS: интересно узнать чужое мнение, так как возможно здесь много субъективщины.</p> <a href="https://habr.com/ru/posts/1015422/?utm_campaign=1015422&amp;utm_source=habrahabr&amp;utm_medium=rss">Читать дальше &rarr;</a>]]></description>
      
    <pubDate>Tue, 31 Mar 2026 14:21:56 GMT</pubDate>
    <dc:creator><![CDATA[VitBurk]]></dc:creator>
      
      <category><![CDATA[разработка]]></category><category><![CDATA[программирование]]></category><category><![CDATA[мобильная разработка]]></category><category><![CDATA[бот]]></category><category><![CDATA[веб-приложения]]></category><category><![CDATA[rust]]></category>
  </item>
  

	
  

  

  

    

  

  
  <item>
    <title><![CDATA[Пост @blognaumen — Блог компании NAUMEN (+3) — 26.03.2026 14:22]]></title>
    <guid isPermaLink="true">https://habr.com/ru/companies/naumen/posts/1015350/</guid>
    <link>https://habr.com/ru/companies/naumen/posts/1015350/?utm_campaign=1015350&amp;utm_source=habrahabr&amp;utm_medium=rss</link>
    <description><![CDATA[<p>Мы привыкли воспринимать DevTools как инструмент для разработчиков и тестировщиков. Но на практике это хороший источник информации и для других специалистов: через него можно понять, как устроена страница, где возникают проблемы и как интерфейс ведет себя в разных сценариях.</p><p>Попросили Костю, frontend-разработчика Naumen, рассказать, какие возможности DevTools он использует в работе и на что стоит обращать внимание.</p><div class="floating-image"><figure class="float full-width "><img src="https://habrastorage.org/getpro/habr/upload_files/c45/8a6/517/c458a6517f24b94754e77979c1b6be5e.jpg" width="1244" height="462"></figure></div><p><strong>1️⃣ Как открыть DevTools, если F12 не сработал</strong></p><p>Самый простой способ&nbsp;— клавиша <strong>F12</strong>&nbsp;для&nbsp;Windows/Linux. На&nbsp;macOS сочетание отличается, но&nbsp;открыть DevTools можно не&nbsp;только с&nbsp;клавиатуры.</p><p>Например, <strong>через&nbsp;контекстное меню&nbsp;</strong>— нажать правой кнопкой мыши на&nbsp;элемент страницы и&nbsp;<strong>выбрать «Исследовать элемент»</strong>. DevTools откроются сразу на&nbsp;нужном месте.</p><blockquote><p>Иногда DevTools пытаются ограничить на уровне страницы, и стандартный способ не работает. В&nbsp;таких случаях выручают <strong>браузерные расширения </strong>с&nbsp;похожими возможностями.</p></blockquote><p>2️⃣ <strong>Как работать с версткой во вкладке Элементы</strong></p><p>Вкладка <strong>Элементы</strong> показывает DOM-дерево страницы — структуру документа, из которого собран интерфейс.&nbsp;</p><p>Здесь можно:</p><ul><li><p>навести курсор на элемент и посмотреть, где он находится на странице</p></li><li><p>быстро найти нужный блок через селектор</p></li><li><p>посмотреть размеры, фон и отступы </p></li></ul><blockquote><p>А еще можно посмотреть доступность — как элементы переключаются через Tab.</p></blockquote><p>3️⃣ <strong>Как находить итоговые стили&nbsp;</strong></p><p>Если&nbsp;у&nbsp;элемента много CSS-правил, я&nbsp;перехожу во&nbsp;вкладку <strong>Вычисленные</strong>.</p><p>Там&nbsp;собраны<strong> все&nbsp;итоговые стили элемента</strong>&nbsp;— включая те, что&nbsp;пришли через&nbsp;наследование или&nbsp;заданы браузером. Можно быстро найти нужное свойство, например, border-radius, и&nbsp;понять, какое значение реально применяется.</p><p> 4️⃣ <strong>Как проверять изменения без правок в коде</strong></p><p>Элементы можно менять прямо в&nbsp;браузере: редактировать текст, менять цвет, удалять элементы или&nbsp;добавлять&nbsp;их — можно вручную вставить длинный текст и&nbsp;посмотреть, не&nbsp;ломается&nbsp;ли&nbsp;верстка.</p><blockquote><p>После обновления страницы все возвращается как было.</p></blockquote><p>5️⃣ <strong>Как разбирать запросы во вкладке Сеть</strong></p><p>Во&nbsp;вкладке <strong>Сеть</strong> видно, какие запросы отправляет страница и&nbsp;что&nbsp;приходит в&nbsp;ответ. А&nbsp;еще&nbsp;в&nbsp;этой вкладке есть&nbsp;не&nbsp;только список запросов, но&nbsp;и&nbsp;инструменты для&nbsp;фильтрации, поиска и&nbsp;просмотра этапов выполнения. Если&nbsp;нужно исключить что‑то из&nbsp;поиска, можно использовать инверсию или&nbsp;минус в&nbsp;строке фильтра.</p><p>Также&nbsp;можно <strong>сохранить HAR-файл</strong> и&nbsp;передать его&nbsp;разработчику&nbsp;— в&nbsp;нем&nbsp;будет вся&nbsp;история сетевых запросов. Но&nbsp;в&nbsp;HAR попадут только те&nbsp;запросы, которые видны с&nbsp;учетом текущих фильтров.</p><p>6️⃣ <strong>Как подменять ответ бэка</strong></p><p>В&nbsp;DevTools можно изменить ответ запроса и&nbsp;посмотреть, как&nbsp;на&nbsp;него отреагирует интерфейс.</p><blockquote><p>Я&nbsp;использую это, когда нужно проверить нестандартный кейс. Например, подставить более длинный текст или&nbsp;другие данные и&nbsp;посмотреть, что&nbsp;произойдет на&nbsp;странице.</p></blockquote><p>7️⃣<strong> Как проверять работу при медленном интернете</strong></p><p>DevTools позволяют проверить, как&nbsp;работает интерфейс при&nbsp;плохом соединении. Во&nbsp;вкладке Сеть можно:</p><ul><li><p>выбрать готовые профили — 3G, 4G</p></li><li><p>настроить <strong>собственную скорость сети</strong></p></li><li><p>протестировать поведение приложения <strong>в режиме офлайн</strong></p></li></ul><p>8️⃣ <strong>Как работать с локальными данными</strong></p><p>Во вкладке <strong>Приложение</strong> можно посмотреть данные, которые браузер сохраняет на стороне пользователя:</p><ol><li><p><strong>Локальное хранилище</strong>&nbsp;— данные, которые сохраняются надолго и&nbsp;не&nbsp;исчезают после&nbsp;перезагрузки страницы.</p></li><li><p><strong>Сессионное хранилище</strong>&nbsp;— данные, которые живут только пока открыта вкладка.</p></li><li><p><strong>Файлы cookie</strong>&nbsp;— похожи на&nbsp;локальное хранилище, но&nbsp;у&nbsp;них есть&nbsp;срок жизни и&nbsp;дополнительные ограничения по&nbsp;источнику.</p></li></ol><p>Все это можно просматривать, изменять и очищать.&nbsp;</p><p>9️⃣ <strong>Как менять геолокацию и часовой пояс</strong></p><p>DevTools позволяют изменить геолокацию и часовой пояс, <strong>не меняя настройки операционной системы</strong>.</p><p>Можно выбрать готовую точку или указать координаты вручную. Полезно, когда нужно проверить поведение элементов в другом городе, регионе или стране.</p><p>🔟 <strong>Как записывать пользовательские сценарии</strong></p><p>Инструмент <strong>Регистратор</strong> умеет записывать действия пользователя на&nbsp;странице&nbsp;— фиксируются шаги, например, клики и&nbsp;переходы по&nbsp;интерфейсу.</p><p>После&nbsp;записи сценарий можно воспроизвести, отредактировать, сохранить и&nbsp;отправить коллегам.</p> <a href="https://habr.com/ru/posts/1015350/?utm_campaign=1015350&amp;utm_source=habrahabr&amp;utm_medium=rss">Читать дальше &rarr;</a>]]></description>
      
    <pubDate>Thu, 26 Mar 2026 11:22:11 GMT</pubDate>
    <dc:creator><![CDATA[blognaumen (NAUMEN)]]></dc:creator>
      
      <category><![CDATA[DevTools]]></category><category><![CDATA[веб-разработка]]></category><category><![CDATA[frontend]]></category><category><![CDATA[отладка интерфейсов]]></category><category><![CDATA[debugging]]></category>
  </item>
  

	
  

  

  

    

  

  
  <item>
    <title><![CDATA[Пост @ceomt — PHP (+3) — 25.03.2026 08:39]]></title>
    <guid isPermaLink="true">https://habr.com/ru/posts/1014594/</guid>
    <link>https://habr.com/ru/posts/1014594/?utm_campaign=1014594&amp;utm_source=habrahabr&amp;utm_medium=rss</link>
    <description><![CDATA[<p><strong>Выпустили бесплатный курс для PHP-разработчиков</strong></p><figure class="full-width "><img src="https://habrastorage.org/getpro/habr/upload_files/8e7/86d/2aa/8e786d2aa9b0c3b0cfc2ac4b61307939.png" alt="Пример одного из уроков курса" title="Пример одного из уроков курса" width="1280" height="720"><div><figcaption>Пример одного из уроков курса</figcaption></div></figure><p>Всем привет! Год назад рассказывал в <a href="https://habr.com/ru/articles/875194/" rel="noopener noreferrer nofollow">этой статье на Хабре</a> о том, как мы подготовили и записали курс на 30+ часов для наших PHP-разработчиков. В итоге у нас вышло 43 урока, разбитые на 5 направлений.</p><p>Сначала думали упаковать все это в коммерческий формат, но решили оставить все как есть и просто поделиться с сообществом. Надеюсь, что он принесет вам пользу.  </p><p><a href="https://mediaten.ru/education/backend" rel="noopener noreferrer nofollow">Курс охватывает PHP от базовых механизмов до архитектуры и тестирования</a>. В программе — устройство языка, работа с памятью и производительностью, принципы ООП и проектирования, а также взаимодействие с базами данных.</p><p>Отдельные блоки посвящены внутренностям PHP (zval, сборщик мусора, OPcache, асинхронность), архитектурным подходам (SOLID, DDD, паттерны, организация бизнес-логики) и работе с БД — от проектирования схем до оптимизации запросов и масштабирования.</p><p>В части тестирования рассматриваются TDD, структура тестов и подходы к оценке их качества.</p><p>Материал основан на практических кейсах и разбирает задачи, которые встречаются в реальных проектах.</p><p>  </p> <a href="https://habr.com/ru/posts/1014594/?utm_campaign=1014594&amp;utm_source=habrahabr&amp;utm_medium=rss">Читать дальше &rarr;</a>]]></description>
      
    <pubDate>Wed, 25 Mar 2026 05:39:11 GMT</pubDate>
    <dc:creator><![CDATA[ceomt]]></dc:creator>
      
      <category><![CDATA[php-программист]]></category><category><![CDATA[бесплатные курсы]]></category>
  </item>
  

	
  

  

  

    

  

  
  <item>
    <title><![CDATA[Пост @denis-19 — Open source (+4) — 20.03.2026 13:40]]></title>
    <guid isPermaLink="true">https://habr.com/ru/posts/1012678/</guid>
    <link>https://habr.com/ru/posts/1012678/?utm_campaign=1012678&amp;utm_source=habrahabr&amp;utm_medium=rss</link>
    <description><![CDATA[<p>Представлен открытый проект <a href="https://github.com/spinov001-art/awesome-web-scraping-2026" rel="noopener noreferrer nofollow">Awesome Web Scraping Tools 2026</a> с веб-скрейперами с API-ориентированным подходом (YouTube, Bluesky, Reddit, Google Maps).</p><p>Все инструменты бесплатны и доступны в <a href="https://apify.com/store" rel="noopener noreferrer nofollow">Apify Store</a>, включая компоненты для:</p><ul><li><p>API-first — более 20 инструментов используют официальные API (Reddit JSON, YouTube Innertube, Wikipedia MediaWiki);</p></li><li><p>JSON-LD вместо CSS — для сайтов с обзорами структурированные данные более надежны;</p></li><li><p>бесплатных API — CoinGecko, Open-Meteo, ip-api, Frankfurter;</p></li><li><p>ограничения скорости запросов — встроенные задержки, никогда не нацелены на DDoS-атаки на сайты.</p></li></ul><figure class="full-width "><img src="https://habrastorage.org/getpro/habr/upload_files/be4/39d/1a9/be439d1a940debc07733c105f5cffbf9.png" width="788" height="377"></figure> <a href="https://habr.com/ru/posts/1012678/?utm_campaign=1012678&amp;utm_source=habrahabr&amp;utm_medium=rss">Читать дальше &rarr;</a>]]></description>
      
    <pubDate>Fri, 20 Mar 2026 10:40:46 GMT</pubDate>
    <dc:creator><![CDATA[denis-19]]></dc:creator>
      
      <category><![CDATA[веб-скрейперы]]></category>
  </item>
  

	
  

  

  

    

  

  
  <item>
    <title><![CDATA[Пост @sergeytolkachyov — Joomla (+4) — 17.03.2026 08:20]]></title>
    <guid isPermaLink="true">https://habr.com/ru/posts/1011098/</guid>
    <link>https://habr.com/ru/posts/1011098/?utm_campaign=1011098&amp;utm_source=habrahabr&amp;utm_medium=rss</link>
    <description><![CDATA[<p><strong>WT CDEK library v.1.3.0 - обновление PHP SDK для Joomla + CDEK.</strong></p><figure class="full-width "><img src="https://habrastorage.org/getpro/habr/upload_files/1c7/764/fee/1c7764fee34e3292ba69e3c18366cac8.png" width="1048" height="857"></figure><p>Небольшая нативная PHP Joomla библиотека для работы с API v.2 службы доставки CDEK. Библиотека представляет собой клиент для авторизации в CDEK API по OAuth, работы с некоторыми методами API: получения ряда данных и расчета стоимости доставки. Поддерживается Joomla 4.2.7 и выше.</p><p>В пакет входят:</p><ul><li><p>библиотека Webtolk/Cdekapi</p></li><li><p>системный плагин System&nbsp;— WT Cdek для&nbsp;хранения настроек и AJAX‑интеграций</p></li><li><p>task‑плагин Task&nbsp;— Update WT Cdek data для&nbsp;обновления локальных копий справочников CDEK по&nbsp;расписанию</p></li><li><p>web asset с&nbsp;официальным JavaScript‑виджетом СДЭК</p></li></ul><p><strong>👉 v.1.3.0. Что нового?</strong></p><ul><li><p>Полный рефакторинг библиотеки. Библиотека переработана в&nbsp;entity‑based API с&nbsp;фасадом Cdek и отдельным слоем запросов. Обратная совместимость не&nbsp;нарушена, поэтому версия библиотеки&nbsp;— 1.3.0.</p></li><li><p>Добавлена поддержка новых разделов API СДЭК. Добавлена поддержка новых разделов API СДЭК: webhooks, prealert, печатные формы, payment, passport, reverse, intakes и других сущностей.</p></li><li><p>Улучшена интеграция с&nbsp;Joomla. Улучшена интеграция с&nbsp;Joomla: installer script для&nbsp;layouts, новые поля Joomla Form для&nbsp;тарифов и обновлённые js виджета CDEK.</p></li><li><p>документация библиотеки. Все методы библиотеки подробно описаны, а&nbsp;так&nbsp;же текст документации собран в&nbsp;отдельной папке в&nbsp;git репозитории.</p></li></ul><p>Пример запроса&nbsp;— запрос информации о&nbsp;городе.</p><pre><code class="php">&lt;?php

use Webtolk\Cdekapi\Cdek;

\defined('_JEXEC') or die;

// Вариант 1: брать credentials из настроек плагина
$cdek = new Cdek();

// Вариант 2: передать credentials явно
$cdek = new Cdek(test_mode: true, client_id: 'your_client_id', client_secret: 'your_client_secret');

$result = $cdek-&gt;location()-&gt;getCities([
    'postal_code' =&gt; '410012',
    'city'        =&gt; 'Саратов',
    'size'        =&gt; 1,
]);
</code></pre><p>Результат запроса:</p><pre><code>Array
(
    [0] =&gt; Array
        (
            [code] =&gt; 428
            [city_uuid] =&gt; 7e54a0b3-76f0-41e2-92e0-f1e600ad84fd
            [city] =&gt; Саратов
            [fias_guid] =&gt; bf465fda-7834-47d5-986b-ccdb584a85a6
            [country_code] =&gt; RU
            [country] =&gt; Россия
            [region] =&gt; Саратовская область
            [region_code] =&gt; 47
            [fias_region_guid] =&gt; df594e0e-a935-4664-9d26-0bae13f904fe
            [sub_region] =&gt; городской округ Саратов
            [longitude] =&gt; 46.034266
            [latitude] =&gt; 51.533562
            [time_zone] =&gt; Europe/Saratov
            [payment_limit] =&gt; -1
        )

)</code></pre><p>Библиотека эта нужна для разработчиков, создающих свои расширения для интеграции Joomla и курьерской службы CDEK.</p><p><a href="https://web-tolk.ru/dev/biblioteki/wt-cdek-library-for-joomla-developers" rel="noopener noreferrer nofollow">Страница расширения</a></p><p><a href="https://github.com/WebTolk/WT-CDEK-Joomla-PHP-library" rel="noopener noreferrer nofollow">GitHub расширения</a> </p> <a href="https://habr.com/ru/posts/1011098/?utm_campaign=1011098&amp;utm_source=habrahabr&amp;utm_medium=rss">Читать дальше &rarr;</a>]]></description>
      
    <pubDate>Tue, 17 Mar 2026 05:20:35 GMT</pubDate>
    <dc:creator><![CDATA[sergeytolkachyov]]></dc:creator>
      
      <category><![CDATA[joomla]]></category><category><![CDATA[cdek]]></category><category><![CDATA[php sdk]]></category><category><![CDATA[php]]></category>
  </item>
  

	
  

  

  

    

  

  
  <item>
    <title><![CDATA[Пост @DmitryOlkhovoi — Веб-разработка (+1) — 16.03.2026 20:16]]></title>
    <guid isPermaLink="true">https://habr.com/ru/posts/1011002/</guid>
    <link>https://habr.com/ru/posts/1011002/?utm_campaign=1011002&amp;utm_source=habrahabr&amp;utm_medium=rss</link>
    <description><![CDATA[<figure class="full-width "><img src="https://habrastorage.org/getpro/habr/upload_files/5d0/361/06f/5d036106fa32eb9a548e22391f736305.png" width="1516" height="1490"></figure><p>Собрал форк Backbone.js без jQuery, Underscore.<br>Typescript, ES module, поддержка классов<br><a href="https://ostovjs.org/" rel="noopener noreferrer nofollow">https://ostovjs.org/</a><br><a href="https://github.com/DmitryOlkhovoi/Ostov" rel="noopener noreferrer nofollow">https://github.com/DmitryOlkhovoi/Ostov</a></p> <a href="https://habr.com/ru/posts/1011002/?utm_campaign=1011002&amp;utm_source=habrahabr&amp;utm_medium=rss">Читать дальше &rarr;</a>]]></description>
      
    <pubDate>Mon, 16 Mar 2026 17:16:33 GMT</pubDate>
    <dc:creator><![CDATA[DmitryOlkhovoi]]></dc:creator>
      
      <category><![CDATA[backbone]]></category><category><![CDATA[jquery]]></category><category><![CDATA[underscore]]></category><category><![CDATA[javascript]]></category>
  </item>
  

	
  

  

  

    

  

  
  <item>
    <title><![CDATA[Пост @myshkin_does_it — Python (+1) — 14.03.2026 14:57]]></title>
    <guid isPermaLink="true">https://habr.com/ru/posts/1010186/</guid>
    <link>https://habr.com/ru/posts/1010186/?utm_campaign=1010186&amp;utm_source=habrahabr&amp;utm_medium=rss</link>
    <description><![CDATA[<p><strong>Два факта об int в</strong> <strong>Python</strong></p><p>Один забавный факт привел меня к открытию другого :)</p><p>Читал Fluent Python и наткнулся на пример кода, который меня заинтересовал (помимо миллиона других, книга – топ). В главе про конкурентность и работу GIL была константа <code>NUMBERS</code> с необычным значением:</p><pre><code class="python">NUMBERS = 5_000_111_000_222_021</code></pre><p><strong>Нижние подчеркивания</strong></p><p>Если не встречали в работе или документации, то вряд ли знаете (как и я): в числах можно использовать <code>_</code> для читаемости. Интерпретатор их игнорирует:</p><pre><code class="bash">&gt;&gt;&gt; x = 1_2
&gt;&gt;&gt; y = 12
&gt;&gt;&gt; x == y
True
&gt;&gt;&gt; x is y
True</code></pre><p>Особенно удобно в высокоразрядных числах. Согласитесь <code>5_000_111_000_222_021</code> куда проще читать, чем <code>5000111000222021</code></p><p><strong>Кеш малых чисел</strong></p><p>Примеры ниже разбирал на домашнем ноуте с Cpython 3.13.11 и 3.14.3.</p><p>Пока игрался, меня заинтересовал один прикол. Я попробовал тот же пример с большими числами:</p><pre><code class="bash">&gt;&gt;&gt; x = 100_500
&gt;&gt;&gt; y = 100500
&gt;&gt;&gt; x == y
True
&gt;&gt;&gt; x is y
False # Но ведь в примере выше было True..</code></pre><p>Почему переменные больше не ссылаются на один объект?</p><p>В Cpython есть кеш для маленьких чисел, чтобы частые значения переменных не занимали много памяти и код был отзывчивее.</p><p>Ответ на вопрос: «где граница, до которой числа закешированы?» я решил не гуглить, проверил небольшим скриптом:</p><pre><code class="bash">&gt;&gt;&gt; x = 0
&gt;&gt;&gt; y = 0
&gt;&gt;&gt; for n in range(1000):
... &nbsp; &nbsp; print(f'If {x=} and {y=}, x is y: {x is y}')
... &nbsp; &nbsp; x += 1
... &nbsp; &nbsp; y += 1

# Пропустим часть строк
If x=254 and y=254, x is y: True
If x=255 and y=255, x is y: True
If x=256 and y=256, x is y: True
If x=257 and y=257, x is y: False # Вот и граница
If x=258 and y=258, x is y: False&nbsp;
...</code></pre><p>Сначала я сделал эмпирически вывод, что закеширован диапазон 0 – 256. Но после самопроверки с гуглом узнал, что также в амортизированный диапазон входят числа от -5 до -1. Итого : от -5 до 256 включительно.</p><p><strong>UPD 15.03.2026.</strong>  Добрый <a href="https://habr.com/ru/users/zzzzzzerg/" rel="noopener noreferrer nofollow">дядя</a> в комментах принес ссылку на <a href="https://github.com/python/cpython/pull/133160/changes" rel="noopener noreferrer nofollow">pr</a> в Cpython 3.15, где кеш малых чисел увеличен  до 1024 :). Ух, заживем..</p><p>Для присвоения переменным чисел вне диапазона, интерпретатор начнет выделять уже раздельные области памяти и <code>is</code> станет возвращать <code>False</code>.</p><p>Так то. В оптимизации пригодится вряд ли, но удивить друзей в баре сможете.</p> <a href="https://habr.com/ru/posts/1010186/?utm_campaign=1010186&amp;utm_source=habrahabr&amp;utm_medium=rss">Читать дальше &rarr;</a>]]></description>
      
    <pubDate>Sat, 14 Mar 2026 11:57:09 GMT</pubDate>
    <dc:creator><![CDATA[myshkin_does_it]]></dc:creator>
      
      <category><![CDATA[python]]></category><category><![CDATA[integer]]></category><category><![CDATA[оптимизация]]></category>
  </item>
  

	
  

  

  

    

  

  
  <item>
    <title><![CDATA[Пост @toxicmt — Программирование (+2) — 09.03.2026 16:57]]></title>
    <guid isPermaLink="true">https://habr.com/ru/posts/1008182/</guid>
    <link>https://habr.com/ru/posts/1008182/?utm_campaign=1008182&amp;utm_source=habrahabr&amp;utm_medium=rss</link>
    <description><![CDATA[<p><strong>Учимся писать промпты правильно</strong></p><p>Я когда начинал погружаться в агентскую разработку, постоянно испытывал легкое чувство стыда, за то, что делаю все как колхозник, а не как "настоящий инженер", который значит продумал задачу, разложил на шаги, обсудил с ии, дальше итеративно, задав кучу условий и ограничений начал реализовывать.</p><p>Мой подход&nbsp; "надо сделать вот это" и дальше уже куда поведет его и куда поведет меня. И это действительно было проблемой, когда я работал в агентах без режима планирования. Доходило до смешного, ты хотел с ним поговорить, он начинает херачить, ты ему "стоять нахер", он там уже наломал дров. В итоге постоянно откатывался сам либо просил откатывать его. В целом, это тоже хороший опыт, понимания того как вообще такие системы работают, где у них границы, как лучше формулировать и так далее.</p><p>Но в любом случае, даже это не приучило меня как-то сидеть и расписывать, потому что ты никогда точно не знаешь, куда поведет агента на чем он запнется. Тебе мерещится одно, а он начинает тупить ваще в неожиданном месте.</p><p>А потом появился режим планирования. И в этот момент, все эти обучалки и принципы того как надо заранее хорошо подумать над задачей превратились в тыкву. Даже если вы начинаете мычать что-то в терминале, современные агенты сами направят, сами зададут вопросы и подсветят важные моменты. Главное в целом понимать что вам нужно и каким будет финальный результат. В этот момент мне перестало быть стыдно.</p><p>Вдруг меня осенило, слишком сильное обдумывание до начала работы в агентской разработке (последние полгода), стало чем-то сродни преждевременной оптимизации. Поработав с большим числом моделей и агентов, могу сказать, что если вы будете сами все продумывать, то заставите работать более менее нормально даже самые тупые модели, но вы никогда не поймете границы их возможностей, где они могут еще больше взять на себя освободив вас от рутины. А модели и агенты постоянно развиваются, там где раньше надо было подсказывать, теперь они могут сами. Плюс если вы работаете над <a href="http://AGENTS.md" rel="noopener noreferrer nofollow">AGENTS.md</a>, скилами и mcp, то и тут мы ловим буст.</p><p>Поэтому сейчас я иду по такому пути. Включаю режим планирования и дальше даю короткое описание задачи и подробный контекст.</p><p>Для упавшего ci это выглядит так:</p><ol><li><p>Поправь тесты</p></li><li><p>Прошу посмотреть последний запущенный билд на github actions</p></li></ol><p>Баг в браузере:</p><ol><li><p>прошу открыть страницу (он это делает через mcp chrome) и самому изучить</p></li></ol><p>Для рефакторинга:</p><ol><li><p>Переводим вот это на это</p></li><li><p>Вот эталон (тут ссылка на файл)</p></li></ol><p>Для фичи:</p><ol><li><p>Нужно реализовать такую фичу</p></li><li><p>Даю пример или говорю с помощью какого инструмента</p></li></ol><p>И все. Самые продвинутые модели типа opus 4.6 или codex 5.3 справятся самостоятельно с большинством острых углов. Сами спросят объем, посмотрят разные варианты, изучат доку и так далее. Модели по тупее, не сделают глубокого анализа и ничего особо не спросят, но именно тут вы поймете где их надо вести и включать свой мозг чаще. Хотя хорошие модели настолько сильно помогают, что я физически не могу использовать более простые для задач планирования. Они хороши в авторежиме только для работы по аналогии, рефакторинг, написание тестов и так далее.</p><p>Даже если вы что-то забудете или пропустите сразу, все это можно будет доуточнить, попросить показать примеры кода, сходить открыть браузер. Если в процессе появляются вещи, которые агент делает из раза в раз, например, пытается выяснить где что-то лежит, как работать с какой-то частью системы, то постепенно это выносится в <a href="http://AGENTS.md" rel="noopener noreferrer nofollow">AGENTS.md</a> и с определенного размера и уровни сложности (когда уже нужны скрипты например и команды) выносится в skill.</p> <a href="https://habr.com/ru/posts/1008182/?utm_campaign=1008182&amp;utm_source=habrahabr&amp;utm_medium=rss">Читать дальше &rarr;</a>]]></description>
      
    <pubDate>Mon, 09 Mar 2026 13:57:30 GMT</pubDate>
    <dc:creator><![CDATA[toxicmt]]></dc:creator>
      
      <category><![CDATA[ии]]></category><category><![CDATA[агенты]]></category><category><![CDATA[нас не заменят]]></category>
  </item>
  

	
  

  

  

    

  

  
  <item>
    <title><![CDATA[Пост @shanker — Информационная безопасность (+4) — 07.03.2026 20:53]]></title>
    <guid isPermaLink="true">https://habr.com/ru/posts/1007772/</guid>
    <link>https://habr.com/ru/posts/1007772/?utm_campaign=1007772&amp;utm_source=habrahabr&amp;utm_medium=rss</link>
    <description><![CDATA[<p><strong>А зачем покупаете WAF, который можно обойти?</strong></p><p>С таким вопросом разработчиков периодически сталкиваюсь.  Добавлю контекста. Работаю AppSec инженером в финтехе. Когда нахожу уязвимости — сообщаю разработчикам. Среди прочего - доношу мысль: если в данном случае можно смягчить потеницальные последствия угрозы через <abbr class="habraabbr" title="Web Application Firewall" data-title="&lt;p&gt;Web Application Firewall&lt;/p&gt;" data-abbr="WAF">WAF</abbr> — это не значит, что уязвимость не нужно исправлять в приложении. Нередко разработчики спорят. Примерный диалог:</p><blockquote><p>— Ну, есть же WAF — на нём и делайте фикс, зачем нам-то в код лезть? WAF — он же для того и нужен, чтоб уязвимости устранять.<br>— WAF — не панацея: на нём мы сделаем правило. Но это не значит, что в самом приложении не нужно устранять.<br>— Почему?<br>— Например, потому, что практически любой WAF можно обойти.<br>— <strong>А зачем покупаете WAF, который можно обойти?</strong></p></blockquote><p>Отвечаю так: потому что WAF пишут такие же разработчики, как Вы, и они тоже иногда ошибаются (как и все люди). Некоторые особо настырные разработчики желают доказательств, что WAF можно обойти. В целом я солидарен, что <a href="https://t.me/avleonovrus/814" rel="noopener noreferrer nofollow">практика "а ты докажи" в управлении уязвимостями - не очень хороша</a>. Но, если есть под рукой на что можно быстро сослаться - можно это сделать. Я ссылаюсь на <a href="https://habr.com/ru/articles/984632/" rel="noopener noreferrer nofollow">эту статью</a>.<br>В моей практике были случаи, когда WAF из-за сбоя переставал применять правила на несколько дней. Т.е. трафик через него шёл, сервис за WAF продолжал быть доступным. Но, правила на WAF не работали — будто их и нет.</p><p>Эта история в очередной раз показывает: насколько бывают различны в оценке ситуации разработчики и "безопасники". Более интересный вариант — когда разработчики считают, что только они могут решать: что является уязвимостью, а что — нет (подробнее об этом я писал в статье "<a href="https://habr.com/ru/articles/927672/" rel="noopener noreferrer nofollow">Как я зарегистрировал CVE и разозлил вендора</a>").</p> <a href="https://habr.com/ru/posts/1007772/?utm_campaign=1007772&amp;utm_source=habrahabr&amp;utm_medium=rss">Читать дальше &rarr;</a>]]></description>
      
    <pubDate>Sat, 07 Mar 2026 17:53:41 GMT</pubDate>
    <dc:creator><![CDATA[shanker]]></dc:creator>
      
      <category><![CDATA[waf]]></category><category><![CDATA[web application firewall]]></category><category><![CDATA[рбпо]]></category><category><![CDATA[безопасная разработка]]></category><category><![CDATA[безопасная инфраструктура]]></category>
  </item>
  

	
  

  

  

    

  

  
  <item>
    <title><![CDATA[Пост @myshkin_does_it — Python (+2) — 01.03.2026 21:30]]></title>
    <guid isPermaLink="true">https://habr.com/ru/posts/1005252/</guid>
    <link>https://habr.com/ru/posts/1005252/?utm_campaign=1005252&amp;utm_source=habrahabr&amp;utm_medium=rss</link>
    <description><![CDATA[<p><strong>Экономия памяти со <code>__slots__</code></strong></p><p>В Python атрибуты классов по-умолчанию хранятся в специальном dunder-атрибуте  <code>__dict__</code>. В описании класса его задавать не надо, он есть неявно и доступен для просмотра при необходимости. Каждый экземпляр класса также имеет свой <code>__dict__</code>:</p><pre><code class="python">class Standard:
	def __init__(self, x, y):
		self.x = x
		self.y = y
		
std = Standard(100, 200)
std.__dict__ # {'x': 100, 'y': 200}
</code></pre><p>Помимо того, что и класс и экземпляры отдельно занимают своими <strong><code>__dict__</code></strong> место в памяти, хранение данных в словарях само по себе несет большие накладные расходы. Хеш-таблица в основе словаря хранит служебные структуры и растёт скачками при увеличении числа атрибутов, поэтому на больших количествах объектов затраты памяти ощутимы:</p><pre><code class="python">from sys import getsizeof

std_size = getsizeof(std) + getsizeof(std.__dict__)
std_size # 344 байта
</code></pre><p>Один из эффективных способов сэкономить память, это реализовать в классе  специальный атрибут <code>__slots__</code> и объявить в нем последовательность атрибутов  экземпляра. Тогда вместо <code>__dict__</code>, Python будет использовать альтернативную структуру хранения атрибутов с помощью дескрипторов.  <code>__slots__</code> для экземпляров классов отдельно не создается и хранится только на уровне класса:</p><pre><code class="python">class Slot:
	__slots__ = ('x', 'y') # Неизменный кортеж из имен атрибутов
	
	def __init__(self, x, y): # Остальное – без изменений
		self.x = x
		self.y = y
		
slt = Slot(100, 200)
slt.__dict__ # **AttributeError**: 'Slot' object has no attribute '__dict__'. Did you mean: '__dir__'?

slt_size = getsizeof(slt)
slt_size # 48 байтов
</code></pre><p>Так добавив одну строчку кода, можно сэкономить расходы памяти в  приложении, где требуется создавать миллионы одинаковых объектов.</p><p>---<br><strong>Важные ограничения</strong></p><ol><li><p>Стоит отметить, что реализация <code>__slots__</code> запрещает динамически добавлять экземпляру класса атрибуты, в отличие от <code>__dict__</code>. В ситуациях, где такое необходимо, <code>__slots__</code> не подойдет.</p><pre><code class="python">std.z = 300
std.__dict__ # {'x': 100, 'y': 200, 'z': 300}

slt.z = 300 # **AttributeError**: 'Slot' object has no attribute 'z' and no __dict__ for setting new attributes
</code></pre></li><li><p>Важно, не забывать расширять слоты, если мы добавляем в код класса новые атрибуты:</p><pre><code class="python">class PartialSlots:
	__slots__ = ('x', 'y') # Не добавили атрибут экземпляра 'z'
	
	def __init__(self, x, y, z):
		self.x = x
		self.y = y
		self.z = z

p = PartialSlots(100, 200, 300) # **AttributeError**: 'PartialSlots' object has no attribute 'z' and no __dict__ for setting new attributes
</code></pre></li><li><p>В подклассах от класса со <code>__slots__</code> наследование этого атрибута проходит лишь частично. Для полноценного использования, его стоит определить еще раз, включив новые атрибуты подкласса:</p><pre><code class="python"># Подкласс без доп. логики
class InheritSlot(Slot):
&nbsp; &nbsp; pass


inh_slt = InheritSlot(100, 200)

inh_slt.__dict__ # {}, атрибут снова доступен
inh_slt.z = 300 # Нет ошибок при динамическом расширении атрибутов
inh_slt.__dict__ # {'z': 300}, словарь подкласса снова занимает память

# Поправим
class InheritSlot(Slot):&nbsp;
&nbsp;&nbsp; &nbsp; __slots__ = ('z', ) # Слоты суперкласса добавятся в начало кортежа. В конце не забываем запятую, так как это кортеж из одного элемента.


inh_slt2 = InheritSlot(100, 200, 300)
inh_slt2.__dict__ # AttributeError ... теперь слоты используются корректно в подклассе</code></pre></li></ol> <a href="https://habr.com/ru/posts/1005252/?utm_campaign=1005252&amp;utm_source=habrahabr&amp;utm_medium=rss">Читать дальше &rarr;</a>]]></description>
      
    <pubDate>Sun, 01 Mar 2026 18:30:33 GMT</pubDate>
    <dc:creator><![CDATA[myshkin_does_it]]></dc:creator>
      
      <category><![CDATA[python]]></category><category><![CDATA[оптимизация]]></category><category><![CDATA[память]]></category>
  </item>
  

	
  

  

  

    

  

  
  <item>
    <title><![CDATA[Пост @denis-19 — Искусственный интеллект (+4) — 26.02.2026 15:18]]></title>
    <guid isPermaLink="true">https://habr.com/ru/posts/1004022/</guid>
    <link>https://habr.com/ru/posts/1004022/?utm_campaign=1004022&amp;utm_source=habrahabr&amp;utm_medium=rss</link>
    <description><![CDATA[<p>Команда проекта <a href="https://www.pencil.dev/" rel="noopener noreferrer nofollow">Pencil</a>.dev обновила сервис и теперь он генерит любые интерфейсы по&nbsp;клику. В решение&nbsp;внедрили режим «Рой», который создаёт сразу несколько вариаций вашего проекта с помощью шести ИИ‑агентов параллельно. Можно грузить любые файлы и даже кастомные шрифты. Проект поддерживает Antigravity, Copilot, Gemini CLI, Opus 4.6, Sonnet 4.6&nbsp;и даже OpenCode. Результат можно экспортировать во&nbsp;всех самых популярных форматах: PDF, JPG, PNG и WebP. Также стало доступно полноценное приложение для&nbsp;Windows. </p><iframe id="69a03974e1d1260a4c49c18b" src="https://embedd.srv.habr.com/iframe/69a03974e1d1260a4c49c18b" class="embed_video embed__content" allowfullscreen="true"></iframe> <a href="https://habr.com/ru/posts/1004022/?utm_campaign=1004022&amp;utm_source=habrahabr&amp;utm_medium=rss">Читать дальше &rarr;</a>]]></description>
      
    <pubDate>Thu, 26 Feb 2026 12:18:30 GMT</pubDate>
    <dc:creator><![CDATA[denis-19]]></dc:creator>
      
      <category><![CDATA[Pencil.dev]]></category>
  </item>
  

	
  

  

  

    

  

  
  <item>
    <title><![CDATA[Пост @sergeytolkachyov — Joomla (+4) — 25.02.2026 13:46]]></title>
    <guid isPermaLink="true">https://habr.com/ru/posts/1003492/</guid>
    <link>https://habr.com/ru/posts/1003492/?utm_campaign=1003492&amp;utm_source=habrahabr&amp;utm_medium=rss</link>
    <description><![CDATA[<p><strong>Особенность Joomla: json-значения для пользовательских полей и их рендер в subform и вне дочерней формы.</strong></p><p>Опять длинное название, но куда уж без этого...</p><p>Итак,  если вы делаете плагин пользовательского поля - его можно использовать через FieldsHelper. И в процессе ваши данные проходят через различные этапы обработки (недавно <a href="https://habr.com/ru/articles/1000064/" rel="noopener noreferrer nofollow">была статья на эту тему</a>). И может так оказаться, что ваше поле хранит в <code>rawvalue</code> json (и в базе данных соответственно тоже), а в <code>value</code> вы на его основе рендерите значение. Это стандартный подход Joomla. Так работают,  например, поля <code>accessiblemedia</code>.  Однако, если вы поместили ваше поле в дочернюю форму (пользовательское поле типа <code>subform</code> и включили <strong>"Рендеринг значений = Да"</strong>, то у вашего замечательного поля может появиться поломанный Json в <code>value</code> вместо нормального значения.</p><p><strong>Например:</strong></p><pre><code class="json">{&amp;quot;basePath&amp;quot;:&amp;quot;...&amp;quot;,&amp;quot;layout&amp;quot;:&amp;quot;...&amp;quot;}</code></pre><p><strong>❓ Что там под капотом Joomla происходит?</strong></p><ol><li><p>В обычном потоке Joomla сначала вызывает событие <code>onCustomFieldsBeforePrepareField</code>, а потом <code>onCustomFieldsPrepareField</code>.</p></li><li><p>Внутри <code>subform</code> же  для подполей при <code>render_values=1</code> вызывается только событие - <code>onCustomFieldsPrepareField</code>.</p></li><li><p>Если преобразование значения (например, <code>json_decode</code>) сделано в вашем плагине только в <code>beforePrepareField</code>, оно не обработает данные  для подполя и...</p></li><li><p>В шаблоне поля строка заэкранируется (<code>htmlentities</code>), кавычки превратятся <s>в тыкву</s> в <code>&amp;quot;</code> и вы получите кривой json, вместо вашего значения.</p></li></ol><p><strong>👉 Собственно полезный совет по Joomla:</strong></p><p>Для полей, которые могут жить внутри <code>subform</code>, делайте нормализацию значения и в <code>onCustomFieldsPrepareField</code> тоже, не только в <code>beforePrepareField</code>.</p> <a href="https://habr.com/ru/posts/1003492/?utm_campaign=1003492&amp;utm_source=habrahabr&amp;utm_medium=rss">Читать дальше &rarr;</a>]]></description>
      
    <pubDate>Wed, 25 Feb 2026 10:46:01 GMT</pubDate>
    <dc:creator><![CDATA[sergeytolkachyov]]></dc:creator>
      
      <category><![CDATA[joomla]]></category><category><![CDATA[joomla form]]></category><category><![CDATA[joomla form field]]></category><category><![CDATA[joomla fieldshelper]]></category><category><![CDATA[поля]]></category><category><![CDATA[баги]]></category><category><![CDATA[ошибки]]></category>
  </item>
  

	
  

  

  

      

      

      

    
  </channel>
</rss>
