В современной разработке верстальщик играет важную роль — он закладывает основу пользовательского опыта (UX) и визуальной согласованности (UI). Ошибка в отступе или разметке может разрушить впечатление от даже самого красивого дизайна.
Что такое вёрстка
Это процесс превращения дизайнерского макета в интерактивную веб-страницу, которую видит пользователь в браузере. Если дизайнер создаёт визуальный образ сайта, то верстальщик делает его «живым» — добавляет структуру, оформление, адаптивность.
Именно вёрстка соединяет дизайн с программированием, превращая статичную картинку в работающий интерфейс. В коде задаётся, где располагаются элементы, какие у них цвета, отступы, шрифты, а также, как страница адаптируется под разные устройства.
Верстальщик и фронтенд-разработчик — в чём разница
Верстальщик работает с HTML и CSS, иногда с базовым JavaScript, создавая визуальную оболочку сайта. Фронтенд-разработчик идёт дальше — интегрирует вёрстку с логикой приложения, API, фреймворками (React, Vue, Angular). На практике границы размыты: многие современные верстальщики постепенно переходят в фронтенд, осваивая язык программирования и работу с компонентами.
История развития вёрстки 1990-е: таблицы и первая структура
Первые сайты создавались при помощи таблиц (). Каждая строка и ячейка использовались для размещения элементов. Это позволяло «рисовать» структуру, но делало код тяжёлым, негибким.
2000-е: блочная модель и CSS
С появлением CSS разработчики отделили оформление от содержания. Страницы стали строиться на -блоках, а внешний вид — задаваться стилями. Это упростило поддержку кода, позволило вводить стандарты W3C. Появились такие понятия, как семантика, веб-стандарты, валидность — принципы, по которым строится качественная разметка.
2010-е: адаптивность и гибкость
Появление смартфонов изменило подход к проектированию. Страницы стали адаптироваться под разные экраны с помощью media queries. Новые технологии, такие как flexbox и CSS Grid, дали верстальщикам инструменты для построения сложных, но управляемых макетов без костылей.
Сегодня
Современная вёрстка — это не просто HTML и CSS, а целая система: дизайн-системы, UI-киты, препроцессоры, сборщики, автоматизация, тесная интеграция с JavaScript-фреймворками.
Основные технологии вёрстки
В основе любой веб-страницы лежат три кита: HTML, CSS, JavaScript. Каждый выполняет свою роль — структура, оформление, интерактивность.
HTML — структура
HTML (HyperText Markup Language) задаёт «скелет» страницы. С его помощью определяется, где будет заголовок, изображение, меню, форма или подвал сайта.
Пример простой страницы:
HTML поддерживает семантические теги — <header>, <main>, <article>, <section>, <footer> — которые помогают поисковым системам и вспомогательным технологиям (например, экранным дикторам) лучше понимать структуру страницы. Это важно для SEO, для доступности.
CSS — оформление
CSS (Cascading Style Sheets) отвечает за внешний вид сайта: цвета, шрифты, отступы, сетку. Пример базового стиля:
Современный CSS поддерживает мощные инструменты:
-
Flexbox — удобное управление расположением элементов по осям;
-
Grid — гибкие сетки для сложных макетов;
-
Transitions и animations — плавные эффекты, динамика;
-
Media queries — адаптация под мобильные устройства.
Главный принцип CSS — разделение контента и оформления. Это делает код чище, облегчает поддержку: можно менять дизайн, не трогая HTML.
JavaScript — интерактивность
Если HTML задаёт структуру, а CSS — стиль, то JavaScript добавляет жизнь. С его помощью страница реагирует на действия пользователя: открывает меню, проверяет формы, показывает всплывающие окна. JS работает с DOM (Document Object Model) — представлением структуры страницы, которое можно изменять прямо из кода. Пример:
JavaScript делает вёрстку динамичной, превращая статические сайты в полноценные веб-приложения.
Макет сайта и подготовка к вёрстке
Перед тем как начать писать код, верстальщик работает с дизайнерским макетом — визуальной моделью сайта. Макет показывает, как должна выглядеть каждая страница, какие элементы присутствуют, как они ведут себя при взаимодействии.
Где создают макеты
Современные дизайнеры работают в инструментах:
-
Figma — онлайн-платформа с возможностью совместной работы;
-
Adobe Photoshop — для графики и деталей интерфейса;
-
Sketch — популярный инструмент среди дизайнеров macOS.
Как читать макет
Верстальщик анализирует структуру: где расположены блоки, какие отступы, шрифты, цвета, адаптивные состояния. Важно соблюдать принцип pixel perfect — максимальное совпадение результата с макетом.
Взаимодействие с дизайнером
Эффективная коммуникация между дизайнером и верстальщиком экономит часы работы. Задача верстальщика — уточнить спорные моменты, предложить оптимальные решения, предупредить о технических ограничениях. Именно на этом этапе формируется будущий UX: качественная вёрстка не только красивая, она функциональная, логичная, быстрая в работе.
Виды вёрстки
Современная веб-вёрстка может выглядеть по-разному — всё зависит от целей проекта, используемых технологий, требований к адаптивности.
Фиксированная
Размер элементов задаётся в пикселях. Такая страница выглядит одинаково на всех устройствах, но не подстраивается под ширину экрана. Подходит для простых макетов, где важна точность расположения элементов.
Резиновая
Элементы масштабируются относительно окна браузера — за счёт процентных значений ширины и высоты. Контент «тянется», но при этом может терять пропорции. Сегодня резиновая вёрстка часто используется как промежуточный вариант.
Адаптивная
Адаптивная вёрстка — стандарт современной разработки. Макет автоматически перестраивается под размер экрана с помощью media-queries. Например, меню превращается в бургер, колонки складываются в один столбец, а изображения уменьшаются без потери качества.
Валидная и кроссбраузерная
Валидная вёрстка соответствует стандартам W3C, что гарантирует корректное отображение сайта в разных браузерах. Кроссбраузерность обеспечивает одинаковое поведение интерфейса в Chrome, Firefox, Safari, Edge (даже в старых версиях Internet Explorer). В идеале современный сайт совмещает адаптивность, валидность, кроссбраузерность, обеспечивая пользователю стабильный опыт независимо от устройства.
Инструменты верстальщика
Современные инструменты позволяют ускорить работу, при этом поддерживать чистый, единообразный код.
Редакторы и IDE
-
VS Code — бесплатная, гибкая среда с сотнями расширений.
-
WebStorm — профессиональная IDE для HTML, CSS, JS, фреймворков.
-
Sublime Text — лёгкий и быстрый редактор, любимый за минимализм.
Полезные плагины
-
Emmet — ускоряет набор кода с помощью сокращений (container>ul>li*3).
-
Prettier — автоформатирование кода.
-
Live Server — моментальный предпросмотр изменений в браузере.
Системы контроля версий
Даже верстальщики активно используют Git и GitHub для хранения проектов, откатов, совместной работы. Это помогает отслеживать изменения и работать в команде с разработчиками.
Сборщики и препроцессоры
-
Gulp, Webpack, Parcel — автоматизируют минификацию, компиляцию стилей, обновление страниц.
-
Sass, LESS, Stylus — препроцессоры, расширяющие возможности CSS: переменные, вложенность, функции.
Пример кода на Sass:
Такой подход делает стили модульными и переиспользуемыми.
Методологии и принципы организации кода
Грамотная структура кода — половина успеха любой вёрстки. Она облегчает поддержку проекта и работу в команде.
БЭМ (Блок–Элемент–Модификатор)
Методология БЭМ, разработанная в «Яндексе», помогает писать читаемые и масштабируемые CSS-классы.
Пример:
Заголовок
card — блок, card__title — элемент, card--highlighted — модификатор.
Благодаря такой структуре код становится предсказуемым, независимым от контекста.
DRY и читаемость
Принцип DRY (Don’t Repeat Yourself) применим и к вёрстке. Повторяющиеся стили лучше выносить в общие классы. Это сокращает CSS и повышает скорость загрузки.
Модульность и переиспользуемость
Хорошая вёрстка строится из модулей — небольших компонентов (карточки, кнопки, формы), которые можно вставлять в разные части сайта.
Комментарии и структура проекта
Комментарии помогают ориентироваться в коде, особенно на крупных проектах. Разделение CSS по смысловым блокам (header, main, footer) делает проект предсказуемым и удобным для команды.
Проверка и тестирование вёрстки
После завершения кодирования начинается не менее важный этап — проверка качества.
Валидация HTML и CSS
Сервисы W3C Validator помогают проверить код на ошибки. Валидная вёрстка гарантирует совместимость с браузерами и улучшает SEO.
Проверка адаптивности
Инструменты Responsive Design Mode (в Chrome DevTools и Firefox) позволяют тестировать, как страница выглядит на разных устройствах.
Сравнение с макетом
Плагины Pixel Perfect, PerfectPixel, Page Ruler позволяют наложить макет на готовую страницу, увидеть расхождения до пикселя.
Производительность и оптимизация
Проверить скорость загрузки можно с помощью Lighthouse и Web Vitals. Они оценивают время отображения контента, отзывчивость интерфейса и стабильность макета. Качественная вёрстка — это баланс между визуальной точностью, оптимизацией и удобством поддержки.
Современные тенденции
Мир фронтенда развивается стремительно, вместе с ним меняются подходы к вёрстке. Сегодня важно не просто «сделать страницу», а обеспечить удобство, скорость, масштабируемость.
Mobile-first и responsive дизайн
Современная разработка строится по принципу mobile-first — сначала проектируется версия для смартфона, а затем расширяется до десктопа. Это логично: большинство пользователей приходят с мобильных устройств, именно там важно обеспечить удобный интерфейс и минимальные задержки загрузки.
CSS Grid и Flexbox как стандарт
Раньше создание сеток требовало сложных вложений и хака с float’ами. Теперь всё проще: Grid и Flexbox стали золотым стандартом. Grid — для сложных макетов, Flexbox — для гибкого выравнивания элементов в строках и столбцах. Вместе они обеспечивают точный контроль над структурой.
CSS Variables и кастомные свойства
Кастомные свойства (--color-primary, --font-size-base) делают код динамичным. Изменив значение переменной, можно мгновенно поменять цветовую схему или тему сайта. Это особенно актуально для тёмного режима и дизайн-систем.
UI-фреймворки и библиотеки
Быстрая разработка невозможна без готовых решений. Самые популярные инструменты:
-
Bootstrap — проверенная временем библиотека компонентов;
-
Tailwind CSS — утилитарный фреймворк с фокусом на кастомизацию;
-
Material UI — визуальный язык от Google, интегрируемый с React.
UI-фреймворки экономят время, но важно не терять индивидуальность дизайна.
Интерактивная вёрстка
Граница между верстальщиком и фронтендером всё больше стирается. Многие проекты требуют базовых знаний React или Vue — библиотек, которые позволяют создавать динамичные интерфейсы без перезагрузки страниц. Современный верстальщик должен не только знать CSS, но и понимать, как компоненты работают в связке с JavaScript.
Ошибки и советы
Типичные промахи
-
Неверная вложенность элементов. Ошибка в структуре HTML ломает вёрстку на уровне браузера.
-
Избыточные inline-стили. Они усложняют поддержку, противоречат принципам разделения кода.
-
Отсутствие alt у изображений. Это мешает SEO и доступности.
-
Жёсткие размеры без адаптации. Страница «сыплется» на мобильных устройствах.
Советы по оптимизации
- Используйте относительные единицы (em, %, rem) — они позволяют масштабировать интерфейс.
- Минимизируйте и объединяйте CSS-файлы для ускорения загрузки.
- Следите за иерархией заголовков (h1–h6) — это важно для SEO и логики восприятия.
- Структурируйте проект: отдельные папки для стилей, изображений, скриптов.
Оптимизация под производительность
Вёрстка напрямую влияет на скорость сайта. Чем меньше CSS и запросов к серверу — тем быстрее откроется страница. Инструменты вроде Lighthouse помогают оценить и улучшить показатели.
Профессия верстальщика
Вёрстка — одна из самых доступных точек входа в IT, особенно для тех, кто только начинает путь в разработке.
Кто такой верстальщик
Это специалист, который создаёт HTML/CSS-код на основе дизайнерских макетов. Он отвечает за визуальную часть сайта, совместимость с браузерами, адаптивность.
Необходимые навыки
- знание HTML5 и CSS3;
- основы JavaScript;
- принципы адаптивного и кроссбраузерного дизайна;
- умение работать с инструментами (Git, Figma, DevTools).
Карьера и перспективы
Можно расти в нескольких направлениях:
-
Frontend-разработка — логичное продолжение пути;
-
UI-инженерия — специализация на интерфейсах и анимациях;
-
Web performance — оптимизация скорости и качества сайтов.
Спрос на внимательных специалистов с сильным чувством структуры стабильно высок: компании нуждаются в разработчиках, которые умеют превращать дизайн в чистый, гибкий код.
Обучение
Онлайн-школы (Hexlet, Skillfactory, Coursera) предлагают курсы, где студенты шаг за шагом осваивают HTML, CSS, JavaScript на практике. Главное — не просто слушать лекции, а верстать реальные проекты, анализировать ошибки, искать способы улучшить код.
Заключение
Вёрстка — это мост между идеей и её воплощением. Она делает дизайн доступным пользователю, а интерфейс — удобным и красивым. Современный верстальщик сочетает точность инженера и вкус дизайнера. В мире разработки нет мелочей: каждый пиксель важен. Поэтому, если вы только начинаете путь в IT — начните с вёрстки. Она научит вас логике, внимательности, дисциплине кода — качествам хорошего программиста.
<!DOCTYPE html>
<html class="h-100" data-bs-theme="light" data-mantine-color-scheme="light" lang="ru" prefix="og: https://ogp.me/ns#">
<head>
<meta content="width=device-width, initial-scale=1.0" name="viewport">
<meta content="IE=Edge" http-equiv="X-UA-Compatible">
<link crossorigin="true" href="https://cdn.hexlet.io" rel="preconnect">
<link href="https://mc.yandex.ru" rel="preconnect">
<meta content="aa2vrdtq64dub8knuf83lwywit311w" name="facebook-domain-verification">
<link href="/favicon.ico" rel="icon" sizes="any">
<link href="/favicon.svg" rel="icon" type="image/svg+xml">
<link href="/apple-touch-icon.png" rel="apple-touch-icon">
<link href="/manifest.webmanifest" rel="manifest">
<script>
//<![CDATA[
window.gon={};gon.ym_counter="25559621";gon.is_bot=true;gon.applications={};gon.current_user={"id":null,"last_viewed_notification_id":null,"email":null,"state":null,"first_name":"","last_name":"","created_at":"2026-02-26 18:02:19 UTC","current_program":null,"current_team":null,"full_name":"","guest":true,"can_use_paid_features":false,"is_hexlet_employee":false,"sanitized_phone_number":"","can_subscribe":true,"can_renew_education":false};gon.token="C_pIu5ogOtPD0NFE8toJvgPBDrfPLTkKcUUDAfNBox7kK4OMaF6Xs3WT9dz-1fnJw8gjHccax6jMpZlVoUZEcA";gon.locale="ru";gon.language="ru";gon.theme="light";gon.rails_env="production";gon.mobile=false;gon.google={"analytics_key":"UA-1360700-51","optimize_key":"GTM-5QDVFPF"};gon.captcha={"google_v3_site_key":"6LenGbgZAAAAAM7HbrDbn5JlizCSzPcS767c9vaY","yandex_site_key":"ysc1_Vyob5ZPPUdPBsu0ykt8bVFdzsfpoVjQChLGl2b4g19647a89","verification_failed":null};gon.social_signin=false;gon.typoreporter_google_form_id="1FAIpQLSeibfGq-KvWQ2Fyru-zkFFRVTLBuzXAHAoEyN1p49FtDmNoNA";
//]]>
</script>
<meta charset="utf-8">
<title>Что такое Верстка? — Q&A Хекслет</title>
<meta name="description" content="2 ответа на вопрос, что такое Верстка простыми словами? Глоссарий Хекслета.">
<link rel="canonical" href="https://ru.hexlet.io/qna/glossary/questions/chto-takoe-verstka">
<meta property="og:description" content="2 ответа
на вопрос, что такое Верстка простыми словами? Глоссарий Хекслета.">
<meta property="og:title" content="Что такое Верстка? — Q&A Хекслет">
<meta property="og:url" content="https://ru.hexlet.io/qna/glossary/questions/chto-takoe-verstka">
<meta name="csrf-param" content="authenticity_token" />
<meta name="csrf-token" content="Jtjt0AUw2-Da-Ijph2myoEirXWOYP66PDgvUQsM49-DJCSbn9052gGy7rHGLZkLXiKJwyZAIUC2z604WkT8Qjg" />
<script src="/vite/assets/inertia-BIn5nEMk.js" crossorigin="anonymous" type="module"></script><link rel="modulepreload" href="/vite/assets/chunk-DsPFFUou.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/preload-helper-BJ4cLWpC.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/init-DOv3_-Z_.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/ahoy-DrlRQ-1D.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/analytics-cb8xch9l.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/ErrorFallbackBlock-naDSYSy9.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/Surface-DL2bpZA-.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/gon-D3e4yh1x.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/mantine-CGMYrt2Y.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/utils-DRqSHbQE.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/routes-CCH8ilKF.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/extends-C-EagtpE.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/inheritsLoose-BBd-DCVI.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/objectWithoutPropertiesLoose-DRHXDhjp.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/index.esm-DAqKOkZ0.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/Button-CGPUux8l.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/CloseButton-D1euiPao.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/Group-BX48WcuU.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/Loader-BQEY8g6v.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/Modal-Cy3HByv7.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/OptionalPortal-1Hza5P2w.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/Stack-CtjJzfw4.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/Textarea-Ck64llAy.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/Box-B5-OOzBf.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/DirectionProvider-Dc9zdUke.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/events-DJQOhap0.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/use-reduced-motion-D2owz4wa.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/use-disclosure-zKtK5W1r.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/use-hotkeys-Cnc_Rwkb.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/random-id-DOQyszCZ.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/notifications.store-C-3AFSMn.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/exports-C_MrNx_T.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/axios-BEvgo0ym.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/dayjs.min-BkKovM-s.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/i18next-BlSq9s7B.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/client-U9M77rxp.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/react-dom-DaLxUz_h.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/useTranslation-Bx1Cdrkz.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/compiler-runtime-6XxiPFnt.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/jsx-runtime-CwjcCKJi.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/react-CkL4ZRHB.js" as="script" crossorigin="anonymous">
<link rel="stylesheet" href="/vite/assets/application-BqhCP46M.js" />
<script src="/vite/assets/application-Df9RExpe.js" crossorigin="anonymous" type="module"></script><link rel="modulepreload" href="/vite/assets/chunk-DsPFFUou.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/autocomplete-VMNbxKGl.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/routes-CCH8ilKF.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/createPopper-C3aM9r1M.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/js.cookie-D1-O8zkX.js" as="script" crossorigin="anonymous"><link rel="stylesheet" href="/vite/assets/application-C8HjmMaq.css" media="screen" />
<script>
window.ym = function(){(ym.a=ym.a||[]).push(arguments)};
window.addEventListener('load', function() {
setTimeout(function() {
ym.l = 1*new Date();
ym(window.gon.ym_counter, "init", {
clickmap: true,
trackLinks: true,
accurateTrackBounce: true,
webvisor: true
});
// Загружаем скрипт
var k = document.createElement('script');
k.async = 1;
k.src = 'https://mc.yandex.ru/metrika/tag.js';
document.head.appendChild(k);
ym(window.gon.ym_counter, 'getClientID', function(clientID) {
window.ymClientId = clientID;
});
}, 1500);
});
</script>
<!-- Google Tag Manager - deferred -->
<script>
// dataLayer stub сразу — пуши работают до загрузки скрипта
window.dataLayer = window.dataLayer || [];
// Сам скрипт — отложенно после load
window.addEventListener('load', function() {
setTimeout(function() {
dataLayer.push({'gtm.start': new Date().getTime(), event: 'gtm.js'});
var j = document.createElement('script');
j.async = true;
j.src = 'https://www.googletagmanager.com/gtm.js?id=GTM-WK88TH';
document.head.appendChild(j);
}, 1500);
});
</script>
<!-- End Google Tag Manager -->
</head>
<body>
<noscript>
<div>
<img alt="" src="https://mc.yandex.ru/watch/25559621" style="position:absolute; left:-9999px;">
</div>
</noscript>
<header class="sticky-top bg-body">
<nav class="navbar navbar-expand-lg">
<div class="container-xxl">
<a class="navbar-brand" href="/"><img alt="Логотип Хекслета" height="24" src="https://ru.hexlet.io/vite/assets/logo_ru_light-BpiEA1LT.svg" width="96">
</a><button aria-controls="collapsable" aria-expanded="false" aria-label="Меню" class="navbar-toggler border-0 mb-0 mt-1" data-bs-target="#collapsable" data-bs-toggle="collapse">
<span class="navbar-toggler-icon"></span>
</button>
<div class="collapse navbar-collapse" id="collapsable">
<ul class="navbar-nav mb-lg-0 mt-lg-1">
<li class="nav-item dropdown">
<button aria-haspopup class="btn nav-link" data-bs-toggle="dropdown" type="button">
Все курсы
<span class="bi bi-chevron-down align-middle ms-1"></span>
</button>
<ul class="dropdown-menu">
<li>
<a class="dropdown-item d-flex py-2" href="/courses"><div class="fw-bold me-auto">Все что есть</div>
<div class="text-muted">117</div>
</a></li>
<li>
<hr class="dropdown-divider">
</li>
<li class="dropdown-item">
<b>Популярные категории</b>
</li>
<li>
<a class="dropdown-item py-2" href="/courses_devops">Курсы по DevOps
</a></li>
<li>
<a class="dropdown-item py-2" href="/courses_data_analytics">Курсы по аналитике данных
</a></li>
<li>
<a class="dropdown-item py-2" href="/courses_programming">Курсы по программированию
</a></li>
<li>
<a class="dropdown-item py-2" href="/courses_testing">Курсы по тестированию
</a></li>
<li>
<hr class="dropdown-divider">
</li>
<li class="dropdown-item">
<b>Популярные курсы</b>
</li>
<li>
<a class="dropdown-item py-2" href="/programs/devops-engineer-from-scratch">DevOps-инженер с нуля
</a></li>
<li>
<a class="dropdown-item py-2" href="/programs/go">Go-разработчик
</a></li>
<li>
<a class="dropdown-item py-2" href="/programs/java">Java-разработчик
</a></li>
<li>
<a class="dropdown-item py-2" href="/programs/python">Python-разработчик
</a></li>
<li>
<a class="dropdown-item py-2" href="/programs/qa-auto-engineer-java">Автоматизатор тестирования на Java
</a></li>
<li>
<a class="dropdown-item py-2" href="/programs/data-analytics">Аналитик данных
</a></li>
<li>
<a class="dropdown-item py-2" href="/programs/frontend">Фронтенд-разработчик
</a></li>
</ul>
</li>
<li class="nav-item dropdown">
<button aria-haspopup class="btn nav-link" data-bs-toggle="dropdown" type="button">
О Хекслете
<span class="bi bi-chevron-down align-middle"></span>
</button>
<ul class="dropdown-menu bg-body">
<li>
<a class="dropdown-item py-2" href="/pages/about">О нас
</a></li>
<li>
<a class="dropdown-item py-2" href="/blog">Блог
</a></li>
<li>
<span class="dropdown-item py-2 external-link" data-href="https://special.hexlet.io/hse-research" role="button">Результаты (Исследование)
</span></li>
<li>
<span class="dropdown-item py-2 external-link" data-href="https://career.hexlet.io" role="button">Хекслет Карьера
</span></li>
<li>
<a class="dropdown-item py-2" href="/testimonials">Отзывы студентов
</a></li>
<li>
<span class="dropdown-item py-2 external-link" data-href="https://t.me/hexlet_help_bot" role="button">Поддержка (В ТГ)
</span></li>
<li>
<span class="dropdown-item py-2 external-link" data-href="https://special.hexlet.io/referal-program/?promo_creative=priglasite-druzei&promo_name=referal-program&promo_position=promo_position&promo_start=010724&promo_type=link" role="button">Реферальная программа
</span></li>
<li>
<span class="dropdown-item py-2 external-link" data-href="https://special.hexlet.io/certificate" role="button">Подарочные сертификаты
</span></li>
<li>
<span class="dropdown-item py-2 external-link" data-href="https://hh.ru/employer/4307094" role="button">Вакансии
</span></li>
<li>
<span class="dropdown-item d-flex external-link" rel="noopener noreferrer nofollow" data-href="https://b2b.hexlet.io" data-target="_blank" role="button">Компаниям
</span></li>
<li>
<span class="dropdown-item d-flex external-link" rel="noopener noreferrer nofollow" data-href="https://hexly.ru/" data-target="_blank" role="button">Колледж
</span></li>
<li>
<span class="dropdown-item d-flex external-link" rel="noopener noreferrer nofollow" data-href="https://hexlyschool.ru/" data-target="_blank" role="button">Частная школа
</span></li>
</ul>
</li>
<li><a class="nav-link" href="/subscription/new">Подписка</a></li>
</ul>
<ul class="navbar-nav flex-lg-row align-items-lg-center gap-2 ms-auto">
<li>
<a class="nav-link" aria-label="Переключить тему" href="/theme/switch?new_theme=dark"><span aria-hidden="true" class="bi bi-moon"></span>
</a></li>
<li>
<span data-target="_self" class="nav-link external-link" data-href="/u/new" role="button"><span>Регистрация</span>
</span></li>
<li>
<span data-target="_self" class="nav-link external-link" data-href="https://ru.hexlet.io/session/new" role="button"><span>Вход</span>
</span></li>
</ul>
</div>
</div>
</nav>
</header>
<div class="x-container-xxxl">
</div>
<main class="mb-6 min-vh-100 h-100">
<link rel="preload" as="image" href="https://hexlet.io/rails/active_storage/representations/proxy/eyJfcmFpbHMiOnsiZGF0YSI6NDAzNCwicHVyIjoiYmxvYl9pZCJ9fQ==--ba516ea9573bdfcd1d21e2aa0fff8818561828f2/eyJfcmFpbHMiOnsiZGF0YSI6eyJmb3JtYXQiOiJ3ZWJwIiwicmVzaXplX3RvX2xpbWl0IjpbNDAwLDQwMF0sInNhdmVyIjp7InF1YWxpdHkiOjg1fX0sInB1ciI6InZhcmlhdGlvbiJ9fQ==--5b6f46dacd1af664f27558553a58076185091823/Typing-bro.png"/><link rel="preload" as="image" href="https://hexlet.io/rails/active_storage/representations/proxy/eyJfcmFpbHMiOnsiZGF0YSI6MzcyNywicHVyIjoiYmxvYl9pZCJ9fQ==--2d5cbbf5c3b4a73ae4b2c50632305d78f5872e4d/eyJfcmFpbHMiOnsiZGF0YSI6eyJmb3JtYXQiOiJ3ZWJwIiwicmVzaXplX3RvX2xpbWl0IjpbNDAwLDQwMF0sInNhdmVyIjp7InF1YWxpdHkiOjg1fX0sInB1ciI6InZhcmlhdGlvbiJ9fQ==--5b6f46dacd1af664f27558553a58076185091823/Programmer-rafiki.png"/><link rel="preload" as="image" href="https://hexlet.io/rails/active_storage/representations/proxy/eyJfcmFpbHMiOnsiZGF0YSI6NDAwNCwicHVyIjoiYmxvYl9pZCJ9fQ==--43a2eb3595eeebb3357d478cbcb752d0026363de/eyJfcmFpbHMiOnsiZGF0YSI6eyJmb3JtYXQiOiJ3ZWJwIiwicmVzaXplX3RvX2xpbWl0IjpbNDAwLDQwMF0sInNhdmVyIjp7InF1YWxpdHkiOjg1fX0sInB1ciI6InZhcmlhdGlvbiJ9fQ==--5b6f46dacd1af664f27558553a58076185091823/Website%20Creator-cuate.png"/><link rel="preload" as="image" href="https://hexlet.io/rails/active_storage/representations/proxy/eyJfcmFpbHMiOnsiZGF0YSI6NDA0MCwicHVyIjoiYmxvYl9pZCJ9fQ==--137ae65fe79f41b3d5270b8a3b65b38b1621c65b/eyJfcmFpbHMiOnsiZGF0YSI6eyJmb3JtYXQiOiJ3ZWJwIiwicmVzaXplX3RvX2xpbWl0IjpbNDAwLDQwMF0sInNhdmVyIjp7InF1YWxpdHkiOjg1fX0sInB1ciI6InZhcmlhdGlvbiJ9fQ==--5b6f46dacd1af664f27558553a58076185091823/Code%20typing-bro.png"/><link rel="preload" as="image" href="https://hexlet.io/rails/active_storage/representations/proxy/eyJfcmFpbHMiOnsiZGF0YSI6NDAyMiwicHVyIjoiYmxvYl9pZCJ9fQ==--8e763c5a65cfc8d5e67cb29ae3d1881ad23c714e/eyJfcmFpbHMiOnsiZGF0YSI6eyJmb3JtYXQiOiJ3ZWJwIiwicmVzaXplX3RvX2xpbWl0IjpbNDAwLDQwMF0sInNhdmVyIjp7InF1YWxpdHkiOjg1fX0sInB1ciI6InZhcmlhdGlvbiJ9fQ==--5b6f46dacd1af664f27558553a58076185091823/Hand%20coding-bro.png"/><link rel="preload" as="image" href="/vite/assets/development-BVihs_d5.png"/><div id="app" data-page="{"component":"web/qna/questions/show","props":{"errors":{},"locale":"ru","language":"ru","httpsHost":"https://ru.hexlet.io","host":"ru.hexlet.io","colorScheme":"light","auth":{"user":{"id":null,"last_viewed_notification_id":null,"email":null,"state":null,"first_name":"","last_name":"","created_at":"2026-02-26T18:02:19.792Z","current_program":null,"current_team":null,"full_name":"","guest":true,"can_use_paid_features":false,"is_hexlet_employee":false,"sanitized_phone_number":"","can_subscribe":true,"can_renew_education":false}},"cloudflareTurnstileSiteKey":"0x4AAAAAAA15KmeFXzd2H0Xo","vkIdClientId":"51586979","yandexIdClientId":"88d071f1d3384eb4bd1deb37910235c7","formAuthToken":"9mNGsnbj_h2nwihMO6oUfRM1Xb-q1PuiqJOXPsGzFRUZso2FhJ1TfRGBDNQ3peQK0zxwFaLjBQAVcw1qk7Tyew","category":{"id":15,"title":"Глоссарий","slug":"glossary","questions_count":382,"locale":"ru"},"mainStackCategory":{"id":2,"name":"Курсы по веб-разработке","slug":"web_development","short_name":"Веб-разработка","order":190,"state":"published","category_slug":"courses_web_development"},"answerDto":{"id":null,"body":"","meta":{"model":"question_answer","relations":{}}},"question":{"creator":{"id":104929,"email":"feycot@gmail.com","first_name":"Nikolai","last_name":"Gagarinov","telegram":"","full_name":"Nikolai Gagarinov","removed":false},"category":{"id":15,"title":"Глоссарий","slug":"glossary","questions_count":382,"locale":"ru"},"tags":[],"id":3801,"answers_count":2,"slug":"chto-takoe-verstka","state":"published","title":"Верстка","created_at":"2023-06-05T10:02:25.725Z","details":null,"best_answer_id":5219,"related_stacks_count":5},"answers":[{"user":{"id":104929,"email":"feycot@gmail.com","first_name":"Nikolai","last_name":"Gagarinov","telegram":"","full_name":"Nikolai Gagarinov","removed":false},"question":{"creator":{"id":104929,"email":"feycot@gmail.com","first_name":"Nikolai","last_name":"Gagarinov","telegram":"","full_name":"Nikolai Gagarinov","removed":false},"category":{"id":15,"title":"Глоссарий","slug":"glossary","questions_count":382,"locale":"ru"},"tags":[],"id":3801,"answers_count":2,"slug":"chto-takoe-verstka","state":"published","title":"Верстка","created_at":"2023-06-05T10:02:25.725Z","details":null,"best_answer_id":5219,"related_stacks_count":5},"id":5219,"state":"active","body":"В современной разработке верстальщик играет важную роль — он закладывает основу пользовательского опыта (UX) и визуальной согласованности (UI). Ошибка в отступе или разметке может разрушить впечатление от даже самого красивого дизайна.\n\n\n\n## Что такое вёрстка\n\nЭто процесс превращения дизайнерского макета в интерактивную веб-страницу, которую видит пользователь в браузере. Если дизайнер создаёт визуальный образ сайта, то верстальщик делает его «живым» — добавляет структуру, оформление, адаптивность.\n\nИменно вёрстка соединяет дизайн с программированием, превращая статичную картинку в работающий интерфейс. В коде задаётся, где располагаются элементы, какие у них цвета, отступы, шрифты, а также, как страница адаптируется под разные устройства.\n\n### Верстальщик и фронтенд-разработчик — в чём разница\n\nВерстальщик работает с HTML и CSS, иногда с базовым JavaScript, создавая визуальную оболочку сайта. Фронтенд-разработчик идёт дальше — интегрирует вёрстку с логикой приложения, API, фреймворками (React, Vue, Angular). На практике границы размыты: многие современные верстальщики постепенно переходят в фронтенд, осваивая язык программирования и работу с компонентами.\n\n## История развития вёрстки 1990-е: таблицы и первая структура\n\nПервые сайты создавались при помощи таблиц (<table>). Каждая строка и ячейка использовались для размещения элементов. Это позволяло «рисовать» структуру, но делало код тяжёлым, негибким.\n\n### 2000-е: блочная модель и CSS\n\nС появлением CSS разработчики отделили оформление от содержания. Страницы стали строиться на <div>-блоках, а внешний вид — задаваться стилями. Это упростило поддержку кода, позволило вводить стандарты W3C. Появились такие понятия, как семантика, веб-стандарты, валидность — принципы, по которым строится качественная разметка.\n\n### 2010-е: адаптивность и гибкость\n\nПоявление смартфонов изменило подход к проектированию. Страницы стали адаптироваться под разные экраны с помощью media queries. Новые технологии, такие как flexbox и CSS Grid, дали верстальщикам инструменты для построения сложных, но управляемых макетов без костылей.\n\n### Сегодня\n\nСовременная вёрстка — это не просто HTML и CSS, а целая система: дизайн-системы, UI-киты, препроцессоры, сборщики, автоматизация, тесная интеграция с JavaScript-фреймворками.\n\n## Основные технологии вёрстки\n\nВ основе любой веб-страницы лежат три кита: HTML, CSS, JavaScript. Каждый выполняет свою роль — структура, оформление, интерактивность.\n\n### HTML — структура\n\nHTML (HyperText Markup Language) задаёт «скелет» страницы. С его помощью определяется, где будет заголовок, изображение, меню, форма или подвал сайта.\n Пример простой страницы:\n\n```html\n<!DOCTYPE html><html lang=\"ru\"> <head> <meta charset=\"UTF-8\"> <title>Пример страницы</title> </head> <body> <h1>Добро пожаловать!</h1> <p>Это пример базовой HTML-разметки.</p> </body></html>\n```\n\nHTML поддерживает семантические теги — `<header>`, `<main>`, `<article>`, `<section>`, `<footer>` — которые помогают поисковым системам и вспомогательным технологиям (например, экранным дикторам) лучше понимать структуру страницы. Это важно для SEO, для доступности.\n\n### CSS — оформление\n\nCSS (Cascading Style Sheets) отвечает за внешний вид сайта: цвета, шрифты, отступы, сетку. Пример базового стиля:\n\n```css\nbody {\n font-family: Arial,\n sans-serif;\n color: #222;\n background-color: #fafafa;\n margin: 0;\n padding: 0;\n}\n```\n\nСовременный CSS поддерживает мощные инструменты:\n\n* **Flexbox** — удобное управление расположением элементов по осям;\n* **Grid** — гибкие сетки для сложных макетов;\n* **Transitions и animations** — плавные эффекты, динамика;\n* **Media queries** — адаптация под мобильные устройства.\n\nГлавный принцип CSS — разделение контента и оформления. Это делает код чище, облегчает поддержку: можно менять дизайн, не трогая HTML.\n\n### JavaScript — интерактивность\n\nЕсли HTML задаёт структуру, а CSS — стиль, то JavaScript добавляет жизнь. С его помощью страница реагирует на действия пользователя: открывает меню, проверяет формы, показывает всплывающие окна. JS работает с DOM (Document Object Model) — представлением структуры страницы, которое можно изменять прямо из кода. Пример:\n\n```javascript\ndocument.querySelector('h1').style.color = 'blue';\n```\n\nJavaScript делает вёрстку динамичной, превращая статические сайты в полноценные веб-приложения.\n\n## Макет сайта и подготовка к вёрстке\n\nПеред тем как начать писать код, верстальщик работает с дизайнерским макетом — визуальной моделью сайта. Макет показывает, как должна выглядеть каждая страница, какие элементы присутствуют, как они ведут себя при взаимодействии.\n\n### Где создают макеты\n\nСовременные дизайнеры работают в инструментах:\n\n* **Figma** — онлайн-платформа с возможностью совместной работы;\n* **Adobe Photoshop** — для графики и деталей интерфейса;\n* **Sketch** — популярный инструмент среди дизайнеров macOS.\n\n### Как читать макет\n\nВерстальщик анализирует структуру: где расположены блоки, какие отступы, шрифты, цвета, адаптивные состояния. Важно соблюдать принцип pixel perfect — максимальное совпадение результата с макетом.\n\n### Взаимодействие с дизайнером\n\nЭффективная коммуникация между дизайнером и верстальщиком экономит часы работы. Задача верстальщика — уточнить спорные моменты, предложить оптимальные решения, предупредить о технических ограничениях. Именно на этом этапе формируется будущий UX: качественная вёрстка не только красивая, она функциональная, логичная, быстрая в работе.\n\n## Виды вёрстки\n\nСовременная веб-вёрстка может выглядеть по-разному — всё зависит от целей проекта, используемых технологий, требований к адаптивности.\n\n### Фиксированная\n\nРазмер элементов задаётся в пикселях. Такая страница выглядит одинаково на всех устройствах, но не подстраивается под ширину экрана. Подходит для простых макетов, где важна точность расположения элементов.\n\n### Резиновая\n\nЭлементы масштабируются относительно окна браузера — за счёт процентных значений ширины и высоты. Контент «тянется», но при этом может терять пропорции. Сегодня резиновая вёрстка часто используется как промежуточный вариант.\n\n### Адаптивная\n\nАдаптивная вёрстка — стандарт современной разработки. Макет автоматически перестраивается под размер экрана с помощью media-queries. Например, меню превращается в бургер, колонки складываются в один столбец, а изображения уменьшаются без потери качества.\n\n### Валидная и кроссбраузерная\n\nВалидная вёрстка соответствует стандартам W3C, что гарантирует корректное отображение сайта в разных браузерах. Кроссбраузерность обеспечивает одинаковое поведение интерфейса в Chrome, Firefox, Safari, Edge (даже в старых версиях Internet Explorer). В идеале современный сайт совмещает адаптивность, валидность, кроссбраузерность, обеспечивая пользователю стабильный опыт независимо от устройства.\n\n## Инструменты верстальщика\n\nСовременные инструменты позволяют ускорить работу, при этом поддерживать чистый, единообразный код.\n\n### Редакторы и IDE\n\n* **VS Code** — бесплатная, гибкая среда с сотнями расширений.\n* **WebStorm** — профессиональная IDE для HTML, CSS, JS, фреймворков.\n* **Sublime Text** — лёгкий и быстрый редактор, любимый за минимализм.\n\n### Полезные плагины\n\n* **Emmet** — ускоряет набор кода с помощью сокращений (container>ul>li*3).\n* **Prettier** — автоформатирование кода.\n* **Live Server** — моментальный предпросмотр изменений в браузере.\n\n### Системы контроля версий\n\nДаже верстальщики активно используют Git и GitHub для хранения проектов, откатов, совместной работы. Это помогает отслеживать изменения и работать в команде с разработчиками.\n\n### Сборщики и препроцессоры\n\n* **Gulp, Webpack, Parcel** — автоматизируют минификацию, компиляцию стилей, обновление страниц.\n* **Sass, LESS, Stylus** — препроцессоры, расширяющие возможности CSS: переменные, вложенность, функции.\n Пример кода на Sass:\n\n```css\n$main-color: #4a90e2; body { color: $main-color; h1 { font-size: 32px; }}\n```\n\nТакой подход делает стили модульными и переиспользуемыми.\n\n\n\n## Методологии и принципы организации кода\n\nГрамотная структура кода — половина успеха любой вёрстки. Она облегчает поддержку проекта и работу в команде.\n\n### БЭМ (Блок–Элемент–Модификатор)\n\nМетодология БЭМ, разработанная в «Яндексе», помогает писать читаемые и масштабируемые CSS-классы.\nПример:\n\n**<div class=\"card card--highlighted\"> <h2 class=\"card__title\">Заголовок</h2></div>**\n\n**card — блок, card__title — элемент, card--highlighted — модификатор.**\n\nБлагодаря такой структуре код становится предсказуемым, независимым от контекста.\n\n## DRY и читаемость\n\nПринцип DRY (Don’t Repeat Yourself) применим и к вёрстке. Повторяющиеся стили лучше выносить в общие классы. Это сокращает CSS и повышает скорость загрузки.\n\n### Модульность и переиспользуемость\n\nХорошая вёрстка строится из модулей — небольших компонентов (карточки, кнопки, формы), которые можно вставлять в разные части сайта.\n\n### Комментарии и структура проекта\n\nКомментарии помогают ориентироваться в коде, особенно на крупных проектах. Разделение CSS по смысловым блокам (header, main, footer) делает проект предсказуемым и удобным для команды.\n\n## Проверка и тестирование вёрстки\n\nПосле завершения кодирования начинается не менее важный этап — проверка качества.\n\n### Валидация HTML и CSS\n\nСервисы W3C Validator помогают проверить код на ошибки. Валидная вёрстка гарантирует совместимость с браузерами и улучшает SEO.\n\n### Проверка адаптивности\n\nИнструменты Responsive Design Mode (в Chrome DevTools и Firefox) позволяют тестировать, как страница выглядит на разных устройствах.\n\n### Сравнение с макетом\n\nПлагины Pixel Perfect, PerfectPixel, Page Ruler позволяют наложить макет на готовую страницу, увидеть расхождения до пикселя.\n\n### Производительность и оптимизация\n\nПроверить скорость загрузки можно с помощью Lighthouse и Web Vitals. Они оценивают время отображения контента, отзывчивость интерфейса и стабильность макета. Качественная вёрстка — это баланс между визуальной точностью, оптимизацией и удобством поддержки.\n\n## Современные тенденции\n\nМир фронтенда развивается стремительно, вместе с ним меняются подходы к вёрстке. Сегодня важно не просто «сделать страницу», а обеспечить удобство, скорость, масштабируемость.\n\n### Mobile-first и responsive дизайн\n\nСовременная разработка строится по принципу mobile-first — сначала проектируется версия для смартфона, а затем расширяется до десктопа. Это логично: большинство пользователей приходят с мобильных устройств, именно там важно обеспечить удобный интерфейс и минимальные задержки загрузки.\n\n### CSS Grid и Flexbox как стандарт\n\nРаньше создание сеток требовало сложных вложений и хака с float’ами. Теперь всё проще: Grid и Flexbox стали золотым стандартом. Grid — для сложных макетов, Flexbox — для гибкого выравнивания элементов в строках и столбцах. Вместе они обеспечивают точный контроль над структурой.\n\n### CSS Variables и кастомные свойства\n\nКастомные свойства (--color-primary, --font-size-base) делают код динамичным. Изменив значение переменной, можно мгновенно поменять цветовую схему или тему сайта. Это особенно актуально для тёмного режима и дизайн-систем.\n\n### UI-фреймворки и библиотеки\n\nБыстрая разработка невозможна без готовых решений. Самые популярные инструменты:\n\n* **Bootstrap** — проверенная временем библиотека компонентов;\n* **Tailwind CSS** — утилитарный фреймворк с фокусом на кастомизацию;\n* **Material UI** — визуальный язык от Google, интегрируемый с React.\n\nUI-фреймворки экономят время, но важно не терять индивидуальность дизайна.\n\n### Интерактивная вёрстка\n\nГраница между верстальщиком и фронтендером всё больше стирается. Многие проекты требуют базовых знаний React или Vue — библиотек, которые позволяют создавать динамичные интерфейсы без перезагрузки страниц. Современный верстальщик должен не только знать CSS, но и понимать, как компоненты работают в связке с JavaScript.\n\n## Ошибки и советы\n\n### Типичные промахи\n\n1. **Неверная вложенность элементов.** Ошибка в структуре HTML ломает вёрстку на уровне браузера.\n2. **Избыточные inline-стили.** Они усложняют поддержку, противоречат принципам разделения кода.\n3. **Отсутствие alt у изображений.** Это мешает SEO и доступности.\n4. **Жёсткие размеры без адаптации.** Страница «сыплется» на мобильных устройствах.\n\n### Советы по оптимизации\n\n* Используйте относительные единицы (em, %, rem) — они позволяют масштабировать интерфейс.\n* Минимизируйте и объединяйте CSS-файлы для ускорения загрузки.\n* Следите за иерархией заголовков (h1–h6) — это важно для SEO и логики восприятия.\n* Структурируйте проект: отдельные папки для стилей, изображений, скриптов.\n\n### Оптимизация под производительность\n\nВёрстка напрямую влияет на скорость сайта. Чем меньше CSS и запросов к серверу — тем быстрее откроется страница. Инструменты вроде Lighthouse помогают оценить и улучшить показатели.\n\n\n\n## Профессия верстальщика\n\nВёрстка — одна из самых доступных точек входа в IT, особенно для тех, кто только начинает путь в разработке.\n\n### Кто такой верстальщик\n\nЭто специалист, который создаёт HTML/CSS-код на основе дизайнерских макетов. Он отвечает за визуальную часть сайта, совместимость с браузерами, адаптивность.\n\n### Необходимые навыки\n\n* знание **HTML5** и **CSS3**;\n* основы **JavaScript**;\n* принципы адаптивного и кроссбраузерного дизайна;\n* умение работать с инструментами (Git, Figma, DevTools).\n\n### Карьера и перспективы\n\nМожно расти в нескольких направлениях:\n\n* **Frontend-разработка** — логичное продолжение пути;\n* **UI-инженерия** — специализация на интерфейсах и анимациях;\n* **Web performance** — оптимизация скорости и качества сайтов.\n\nСпрос на внимательных специалистов с сильным чувством структуры стабильно высок: компании нуждаются в разработчиках, которые умеют превращать дизайн в чистый, гибкий код.\n\n### Обучение\n\nОнлайн-школы (Hexlet, Skillfactory, Coursera) предлагают курсы, где студенты шаг за шагом осваивают HTML, CSS, JavaScript на практике. Главное — не просто слушать лекции, а верстать реальные проекты, анализировать ошибки, искать способы улучшить код.\n\n## Заключение\n\nВёрстка — это мост между идеей и её воплощением. Она делает дизайн доступным пользователю, а интерфейс — удобным и красивым. Современный верстальщик сочетает точность инженера и вкус дизайнера. В мире разработки нет мелочей: каждый пиксель важен. Поэтому, если вы только начинаете путь в IT — начните с вёрстки. Она научит вас логике, внимательности, дисциплине кода — качествам хорошего программиста.\n","votes_up_count":1,"votes_down_count":0,"created_at":"2025-11-24T19:15:25.564Z","user_id":104929,"category_slug":"glossary"},{"user":{"id":647057,"email":"redkinaelena10.02.89@yandex.ru","first_name":"Елена","last_name":"Редькина","telegram":"89670235676","full_name":"Елена Редькина","removed":false},"question":{"creator":{"id":104929,"email":"feycot@gmail.com","first_name":"Nikolai","last_name":"Gagarinov","telegram":"","full_name":"Nikolai Gagarinov","removed":false},"category":{"id":15,"title":"Глоссарий","slug":"glossary","questions_count":382,"locale":"ru"},"tags":[],"id":3801,"answers_count":2,"slug":"chto-takoe-verstka","state":"published","title":"Верстка","created_at":"2023-06-05T10:02:25.725Z","details":null,"best_answer_id":5219,"related_stacks_count":5},"id":3093,"state":"active","body":"Верстка - это процесс создания макета страницы или документа. В веб-разработке верстка означает создание HTML-кода и CSS-стилей, которые определяют структуру и внешний вид веб-страницы. После верстки страница может быть отображена в браузере и проверена на наличие ошибок.","votes_up_count":0,"votes_down_count":0,"created_at":"2023-11-16T13:42:25.844Z","user_id":647057,"category_slug":"glossary"}],"relatedQuestions":[{"creator":{"id":583099,"email":"shade.mailbox@gmail.com","first_name":"Arthur","last_name":"Cheremisin","telegram":"","full_name":"Arthur Cheremisin","removed":false},"category":{"id":15,"title":"Глоссарий","slug":"glossary","questions_count":382,"locale":"ru"},"tags":[{"id":1095,"slug":"data-analitika","name":"data-аналитика"},{"id":1096,"slug":"analitika","name":"Аналитика"}],"id":2709,"answers_count":2,"slug":"chto-takoe-pandas","state":"published","title":"Pandas","created_at":"2023-03-29T12:39:32.428Z","details":"","best_answer_id":5306,"related_stacks_count":5},{"creator":{"id":104929,"email":"feycot@gmail.com","first_name":"Nikolai","last_name":"Gagarinov","telegram":"","full_name":"Nikolai Gagarinov","removed":false},"category":{"id":15,"title":"Глоссарий","slug":"glossary","questions_count":382,"locale":"ru"},"tags":[],"id":3577,"answers_count":1,"slug":"chto-takoe-1c-buhgalteriya","state":"published","title":"1C:Бухгалтерия","created_at":"2023-06-05T10:02:18.923Z","details":null,"best_answer_id":3315,"related_stacks_count":0},{"creator":{"id":104929,"email":"feycot@gmail.com","first_name":"Nikolai","last_name":"Gagarinov","telegram":"","full_name":"Nikolai Gagarinov","removed":false},"category":{"id":15,"title":"Глоссарий","slug":"glossary","questions_count":382,"locale":"ru"},"tags":[],"id":3578,"answers_count":1,"slug":"chto-takoe-1c-predpriyatie","state":"published","title":"1C:Предприятие","created_at":"2023-06-05T10:02:18.960Z","details":null,"best_answer_id":3314,"related_stacks_count":5},{"creator":{"id":104929,"email":"feycot@gmail.com","first_name":"Nikolai","last_name":"Gagarinov","telegram":"","full_name":"Nikolai Gagarinov","removed":false},"category":{"id":15,"title":"Глоссарий","slug":"glossary","questions_count":382,"locale":"ru"},"tags":[],"id":3579,"answers_count":1,"slug":"chto-takoe-a-b-testirovanie","state":"published","title":"A/B-тестирование","created_at":"2023-06-05T10:02:18.988Z","details":null,"best_answer_id":3313,"related_stacks_count":5},{"creator":{"id":104929,"email":"feycot@gmail.com","first_name":"Nikolai","last_name":"Gagarinov","telegram":"","full_name":"Nikolai Gagarinov","removed":false},"category":{"id":15,"title":"Глоссарий","slug":"glossary","questions_count":382,"locale":"ru"},"tags":[],"id":3580,"answers_count":1,"slug":"chto-takoe-agile","state":"published","title":"Agile","created_at":"2023-06-05T10:02:19.016Z","details":null,"best_answer_id":3312,"related_stacks_count":5}],"relatedLandings":[{"stack":{"id":19,"slug":"layout-designer","title":"Профессиональная верстка","audience":"for_beginners","start_type":"anytime","pricing_model":"purchase","priority":"medium","kind":"track","state":"published","stack_state":"finished","order":1700,"duration_in_months":5},"id":26,"slug":"professional-layout","title":"Профессиональная верстка","subtitle":"Навык адаптивной вёрстки с современными подходами для корректного отображения сайтов на любых устройствах и разрешениях","subtitle_for_lists":"Адаптивная вёрстка для отображения на любых устройствах ","locale":"ru","current":true,"duration_in_months_text":"5 месяцев","stack_slug":"layout-designer","price_text":"от 3 900 ₽","duration_text":"5 месяцев","cover_list_variant":"https://hexlet.io/rails/active_storage/representations/proxy/eyJfcmFpbHMiOnsiZGF0YSI6NDAzNCwicHVyIjoiYmxvYl9pZCJ9fQ==--ba516ea9573bdfcd1d21e2aa0fff8818561828f2/eyJfcmFpbHMiOnsiZGF0YSI6eyJmb3JtYXQiOiJ3ZWJwIiwicmVzaXplX3RvX2xpbWl0IjpbNDAwLDQwMF0sInNhdmVyIjp7InF1YWxpdHkiOjg1fX0sInB1ciI6InZhcmlhdGlvbiJ9fQ==--5b6f46dacd1af664f27558553a58076185091823/Typing-bro.png"},{"stack":{"id":12,"slug":"frontend","title":"Фронтенд-разработчик","audience":"for_beginners","start_type":"weekly","pricing_model":"purchase","priority":"high","kind":"profession","state":"published","stack_state":"finished","order":20,"duration_in_months":10},"id":17,"slug":"frontend","title":"Фронтенд-разработчик","subtitle":"Изучите HTML, CSS, JavaScript и React","subtitle_for_lists":"Изучите HTML, CSS, JavaScript и React","locale":"ru","current":true,"duration_in_months_text":"10 месяцев","stack_slug":"frontend","price_text":"от 6 792 ₽","duration_text":"10 месяцев","cover_list_variant":"https://hexlet.io/rails/active_storage/representations/proxy/eyJfcmFpbHMiOnsiZGF0YSI6MzcyNywicHVyIjoiYmxvYl9pZCJ9fQ==--2d5cbbf5c3b4a73ae4b2c50632305d78f5872e4d/eyJfcmFpbHMiOnsiZGF0YSI6eyJmb3JtYXQiOiJ3ZWJwIiwicmVzaXplX3RvX2xpbWl0IjpbNDAwLDQwMF0sInNhdmVyIjp7InF1YWxpdHkiOjg1fX0sInB1ciI6InZhcmlhdGlvbiJ9fQ==--5b6f46dacd1af664f27558553a58076185091823/Programmer-rafiki.png"},{"stack":{"id":41,"slug":"layout-designer-positioning","title":"Позиционирование в CSS","audience":"for_programmers","start_type":"anytime","pricing_model":"subscription","priority":"medium","kind":"track","state":"published","stack_state":"finished","order":4800,"duration_in_months":1},"id":70,"slug":"layout-designer-positioning","title":"Позиционирование в CSS","subtitle":"Навык разработки адаптивных интерфейсов, позволяющий создавать удобные и функциональные решения для различных устройств","subtitle_for_lists":"Получите навык работы с CSS и адаптивными интерфейсами","locale":"ru","current":true,"duration_in_months_text":"1 месяц","stack_slug":"layout-designer-positioning","price_text":"от 3 900 ₽","duration_text":"1 месяц","cover_list_variant":"https://hexlet.io/rails/active_storage/representations/proxy/eyJfcmFpbHMiOnsiZGF0YSI6NDAwNCwicHVyIjoiYmxvYl9pZCJ9fQ==--43a2eb3595eeebb3357d478cbcb752d0026363de/eyJfcmFpbHMiOnsiZGF0YSI6eyJmb3JtYXQiOiJ3ZWJwIiwicmVzaXplX3RvX2xpbWl0IjpbNDAwLDQwMF0sInNhdmVyIjp7InF1YWxpdHkiOjg1fX0sInB1ciI6InZhcmlhdGlvbiJ9fQ==--5b6f46dacd1af664f27558553a58076185091823/Website%20Creator-cuate.png"},{"stack":{"id":42,"slug":"layout-designer-bootstrap","title":"Bootstrap","audience":"for_programmers","start_type":"anytime","pricing_model":"subscription","priority":"medium","kind":"track","state":"published","stack_state":"finished","order":400,"duration_in_months":2},"id":72,"slug":"layout-designer-bootstrap","title":"Bootstrap","subtitle":"Навык работы с SASS, Bootstrap 5 и Gulp для ускорения, упрощения и оптимизации процесса вёрстки и разработки сайтов","subtitle_for_lists":"Изучите навык для работы с Bootstrap 5, SASS и Gulp для быстрой вёрстки","locale":"ru","current":true,"duration_in_months_text":"2 месяца","stack_slug":"layout-designer-bootstrap","price_text":"от 3 900 ₽","duration_text":"2 месяца","cover_list_variant":"https://hexlet.io/rails/active_storage/representations/proxy/eyJfcmFpbHMiOnsiZGF0YSI6NDA0MCwicHVyIjoiYmxvYl9pZCJ9fQ==--137ae65fe79f41b3d5270b8a3b65b38b1621c65b/eyJfcmFpbHMiOnsiZGF0YSI6eyJmb3JtYXQiOiJ3ZWJwIiwicmVzaXplX3RvX2xpbWl0IjpbNDAwLDQwMF0sInNhdmVyIjp7InF1YWxpdHkiOjg1fX0sInB1ciI6InZhcmlhdGlvbiJ9fQ==--5b6f46dacd1af664f27558553a58076185091823/Code%20typing-bro.png"},{"stack":{"id":133,"slug":"sass","title":"SASS","audience":"for_programmers","start_type":"anytime","pricing_model":"subscription","priority":"medium","kind":"track","state":"published","stack_state":"finished","order":2000,"duration_in_months":1},"id":226,"slug":"sass","title":"SASS","subtitle":"Навык работы с препроцессором SASS для эффективной и структурированной стилизации веб-приложений","subtitle_for_lists":"Освоите препроцессор SASS и стилизацию веб-приложений","locale":"ru","current":true,"duration_in_months_text":"1 месяц","stack_slug":"sass","price_text":"от 3 900 ₽","duration_text":"1 месяц","cover_list_variant":"https://hexlet.io/rails/active_storage/representations/proxy/eyJfcmFpbHMiOnsiZGF0YSI6NDAyMiwicHVyIjoiYmxvYl9pZCJ9fQ==--8e763c5a65cfc8d5e67cb29ae3d1881ad23c714e/eyJfcmFpbHMiOnsiZGF0YSI6eyJmb3JtYXQiOiJ3ZWJwIiwicmVzaXplX3RvX2xpbWl0IjpbNDAwLDQwMF0sInNhdmVyIjp7InF1YWxpdHkiOjg1fX0sInB1ciI6InZhcmlhdGlvbiJ9fQ==--5b6f46dacd1af664f27558553a58076185091823/Hand%20coding-bro.png"}]},"url":"/qna/glossary/questions/chto-takoe-verstka","version":"143505ecd123087a8fdfa4acb7147980e9d23d76","encryptHistory":false,"clearHistory":false}"><style data-mantine-styles="true">:root, :host{--mantine-font-family: Arial, sans-serif;--mantine-font-family-headings: Arial, sans-serif;--mantine-heading-font-weight: normal;--mantine-radius-default: 0rem;--mantine-primary-color-filled: var(--mantine-color-indigo-filled);--mantine-primary-color-filled-hover: var(--mantine-color-indigo-filled-hover);--mantine-primary-color-light: var(--mantine-color-indigo-light);--mantine-primary-color-light-hover: var(--mantine-color-indigo-light-hover);--mantine-primary-color-light-color: var(--mantine-color-indigo-light-color);--mantine-spacing-xxl: calc(4rem * var(--mantine-scale));--mantine-font-size-xs: 12px;--mantine-font-size-sm: 14px;--mantine-font-size-md: 16px;--mantine-font-size-lg: clamp(16.0000px, calc(15.2727px + 0.2273vw), 18.0000px);--mantine-font-size-xl: clamp(16.0000px, calc(14.5455px + 0.4545vw), 20.0000px);--mantine-font-size-display-3: clamp(32.0000px, calc(26.1818px + 1.8182vw), 48.0000px);--mantine-font-size-display-2: clamp(36.0000px, calc(25.8182px + 3.1818vw), 64.0000px);--mantine-font-size-display-1: clamp(40.0000px, calc(25.4545px + 4.5455vw), 80.0000px);--mantine-font-size-h1: clamp(28.0000px, calc(23.6364px + 1.3636vw), 40.0000px);--mantine-font-size-h2: clamp(24.0000px, calc(21.0909px + 0.9091vw), 32.0000px);--mantine-font-size-h3: clamp(20.0000px, calc(17.0909px + 0.9091vw), 28.0000px);--mantine-font-size-h4: clamp(16.0000px, calc(13.0909px + 0.9091vw), 24.0000px);--mantine-font-size-h5: clamp(16.0000px, calc(14.5455px + 0.4545vw), 20.0000px);--mantine-font-size-h6: 1rem;--mantine-primary-color-0: var(--mantine-color-indigo-0);--mantine-primary-color-1: var(--mantine-color-indigo-1);--mantine-primary-color-2: var(--mantine-color-indigo-2);--mantine-primary-color-3: var(--mantine-color-indigo-3);--mantine-primary-color-4: var(--mantine-color-indigo-4);--mantine-primary-color-5: var(--mantine-color-indigo-5);--mantine-primary-color-6: var(--mantine-color-indigo-6);--mantine-primary-color-7: var(--mantine-color-indigo-7);--mantine-primary-color-8: var(--mantine-color-indigo-8);--mantine-primary-color-9: var(--mantine-color-indigo-9);--mantine-color-red-0: #ffeaea;--mantine-color-red-1: #fed4d4;--mantine-color-red-2: #f4a7a8;--mantine-color-red-3: #ec7878;--mantine-color-red-4: #e55050;--mantine-color-red-5: #e03131;--mantine-color-red-6: #e02829;--mantine-color-red-7: #c71a1c;--mantine-color-red-8: #b21218;--mantine-color-red-9: #9c0411;--mantine-color-violet-0: #fce9ff;--mantine-color-violet-1: #f1cfff;--mantine-color-violet-2: #e09bff;--mantine-color-violet-3: #d16fff;--mantine-color-violet-4: #be37fe;--mantine-color-violet-5: #b51afe;--mantine-color-violet-6: #b009ff;--mantine-color-violet-7: #9b00e4;--mantine-color-violet-8: #8a00cc;--mantine-color-violet-9: #7800b3;--mantine-color-indigo-0: #edecff;--mantine-color-indigo-1: #d6d5fe;--mantine-color-indigo-2: #aaa9f4;--mantine-color-indigo-3: #7b79eb;--mantine-color-indigo-4: #5451e4;--mantine-color-indigo-5: #3b37e0;--mantine-color-indigo-6: #2d2adf;--mantine-color-indigo-7: #1f1ec7;--mantine-color-indigo-8: #1819b2;--mantine-color-indigo-9: #0c149e;--mantine-color-cyan-0: #dffdff;--mantine-color-cyan-1: #caf5ff;--mantine-color-cyan-2: #99e8ff;--mantine-color-cyan-3: #64daff;--mantine-color-cyan-4: #3ccffe;--mantine-color-cyan-5: #24c8fe;--mantine-color-cyan-6: #00c2ff;--mantine-color-cyan-7: #00ade4;--mantine-color-cyan-8: #009acd;--mantine-color-cyan-9: #0085b5;--mantine-color-green-0: #e9fdec;--mantine-color-green-1: #d7f6dc;--mantine-color-green-2: #b0eab9;--mantine-color-green-3: #86df94;--mantine-color-green-4: #62d574;--mantine-color-green-5: #4ccf5f;--mantine-color-green-6: #3fcc54;--mantine-color-green-7: #2fb344;--mantine-color-green-8: #25a03b;--mantine-color-green-9: #138a2e;--mantine-color-yellow-0: #fff7e2;--mantine-color-yellow-1: #ffeecd;--mantine-color-yellow-2: #ffdc9c;--mantine-color-yellow-3: #ffc966;--mantine-color-yellow-4: #feb93a;--mantine-color-yellow-5: #feae1e;--mantine-color-yellow-6: #ffa90f;--mantine-color-yellow-8: #ca8200;--mantine-color-yellow-9: #af7000;--mantine-h1-font-size: clamp(28.0000px, calc(23.6364px + 1.3636vw), 40.0000px);--mantine-h1-font-weight: normal;--mantine-h2-font-size: clamp(24.0000px, calc(21.0909px + 0.9091vw), 32.0000px);--mantine-h2-font-weight: normal;--mantine-h3-font-size: clamp(20.0000px, calc(17.0909px + 0.9091vw), 28.0000px);--mantine-h3-font-weight: normal;--mantine-h4-font-size: clamp(16.0000px, calc(13.0909px + 0.9091vw), 24.0000px);--mantine-h4-font-weight: normal;--mantine-h5-font-size: clamp(16.0000px, calc(14.5455px + 0.4545vw), 20.0000px);--mantine-h5-font-weight: normal;--mantine-h6-font-size: 1rem;--mantine-h6-font-weight: normal;}
:root[data-mantine-color-scheme="dark"], :host([data-mantine-color-scheme="dark"]){--mantine-color-anchor: var(--mantine-color-text);--mantine-color-dimmed: #495057;--mantine-color-dark-filled: var(--mantine-color-dark-5);--mantine-color-dark-filled-hover: var(--mantine-color-dark-6);--mantine-color-dark-light: rgba(105, 105, 105, 0.15);--mantine-color-dark-light-hover: rgba(105, 105, 105, 0.2);--mantine-color-dark-light-color: var(--mantine-color-dark-0);--mantine-color-dark-outline: var(--mantine-color-dark-1);--mantine-color-dark-outline-hover: rgba(184, 184, 184, 0.05);--mantine-color-gray-filled: var(--mantine-color-gray-5);--mantine-color-gray-filled-hover: var(--mantine-color-gray-6);--mantine-color-gray-light: rgba(222, 226, 230, 0.15);--mantine-color-gray-light-hover: rgba(222, 226, 230, 0.2);--mantine-color-gray-light-color: var(--mantine-color-gray-0);--mantine-color-gray-outline: var(--mantine-color-gray-1);--mantine-color-gray-outline-hover: rgba(241, 243, 245, 0.05);--mantine-color-red-filled: var(--mantine-color-red-5);--mantine-color-red-filled-hover: var(--mantine-color-red-6);--mantine-color-red-light: rgba(236, 120, 120, 0.15);--mantine-color-red-light-hover: rgba(236, 120, 120, 0.2);--mantine-color-red-light-color: var(--mantine-color-red-0);--mantine-color-red-outline: var(--mantine-color-red-1);--mantine-color-red-outline-hover: rgba(254, 212, 212, 0.05);--mantine-color-pink-filled: var(--mantine-color-pink-5);--mantine-color-pink-filled-hover: var(--mantine-color-pink-6);--mantine-color-pink-light: rgba(250, 162, 193, 0.15);--mantine-color-pink-light-hover: rgba(250, 162, 193, 0.2);--mantine-color-pink-light-color: var(--mantine-color-pink-0);--mantine-color-pink-outline: var(--mantine-color-pink-1);--mantine-color-pink-outline-hover: rgba(255, 222, 235, 0.05);--mantine-color-grape-filled: var(--mantine-color-grape-5);--mantine-color-grape-filled-hover: var(--mantine-color-grape-6);--mantine-color-grape-light: rgba(229, 153, 247, 0.15);--mantine-color-grape-light-hover: rgba(229, 153, 247, 0.2);--mantine-color-grape-light-color: var(--mantine-color-grape-0);--mantine-color-grape-outline: var(--mantine-color-grape-1);--mantine-color-grape-outline-hover: rgba(243, 217, 250, 0.05);--mantine-color-violet-filled: var(--mantine-color-violet-5);--mantine-color-violet-filled-hover: var(--mantine-color-violet-6);--mantine-color-violet-light: rgba(209, 111, 255, 0.15);--mantine-color-violet-light-hover: rgba(209, 111, 255, 0.2);--mantine-color-violet-light-color: var(--mantine-color-violet-0);--mantine-color-violet-outline: var(--mantine-color-violet-1);--mantine-color-violet-outline-hover: rgba(241, 207, 255, 0.05);--mantine-color-indigo-filled: var(--mantine-color-indigo-5);--mantine-color-indigo-filled-hover: var(--mantine-color-indigo-6);--mantine-color-indigo-light: rgba(123, 121, 235, 0.15);--mantine-color-indigo-light-hover: rgba(123, 121, 235, 0.2);--mantine-color-indigo-light-color: var(--mantine-color-indigo-0);--mantine-color-indigo-outline: var(--mantine-color-indigo-1);--mantine-color-indigo-outline-hover: rgba(214, 213, 254, 0.05);--mantine-color-blue-filled: var(--mantine-color-blue-5);--mantine-color-blue-filled-hover: var(--mantine-color-blue-6);--mantine-color-blue-light: rgba(116, 192, 252, 0.15);--mantine-color-blue-light-hover: rgba(116, 192, 252, 0.2);--mantine-color-blue-light-color: var(--mantine-color-blue-0);--mantine-color-blue-outline: var(--mantine-color-blue-1);--mantine-color-blue-outline-hover: rgba(208, 235, 255, 0.05);--mantine-color-cyan-filled: var(--mantine-color-cyan-5);--mantine-color-cyan-filled-hover: var(--mantine-color-cyan-6);--mantine-color-cyan-light: rgba(100, 218, 255, 0.15);--mantine-color-cyan-light-hover: rgba(100, 218, 255, 0.2);--mantine-color-cyan-light-color: var(--mantine-color-cyan-0);--mantine-color-cyan-outline: var(--mantine-color-cyan-1);--mantine-color-cyan-outline-hover: rgba(202, 245, 255, 0.05);--mantine-color-teal-filled: var(--mantine-color-teal-5);--mantine-color-teal-filled-hover: var(--mantine-color-teal-6);--mantine-color-teal-light: rgba(99, 230, 190, 0.15);--mantine-color-teal-light-hover: rgba(99, 230, 190, 0.2);--mantine-color-teal-light-color: var(--mantine-color-teal-0);--mantine-color-teal-outline: var(--mantine-color-teal-1);--mantine-color-teal-outline-hover: rgba(195, 250, 232, 0.05);--mantine-color-green-filled: var(--mantine-color-green-5);--mantine-color-green-filled-hover: var(--mantine-color-green-6);--mantine-color-green-light: rgba(134, 223, 148, 0.15);--mantine-color-green-light-hover: rgba(134, 223, 148, 0.2);--mantine-color-green-light-color: var(--mantine-color-green-0);--mantine-color-green-outline: var(--mantine-color-green-1);--mantine-color-green-outline-hover: rgba(215, 246, 220, 0.05);--mantine-color-lime-filled: var(--mantine-color-lime-5);--mantine-color-lime-filled-hover: var(--mantine-color-lime-6);--mantine-color-lime-light: rgba(192, 235, 117, 0.15);--mantine-color-lime-light-hover: rgba(192, 235, 117, 0.2);--mantine-color-lime-light-color: var(--mantine-color-lime-0);--mantine-color-lime-outline: var(--mantine-color-lime-1);--mantine-color-lime-outline-hover: rgba(233, 250, 200, 0.05);--mantine-color-yellow-filled: var(--mantine-color-yellow-5);--mantine-color-yellow-filled-hover: var(--mantine-color-yellow-6);--mantine-color-yellow-light: rgba(255, 201, 102, 0.15);--mantine-color-yellow-light-hover: rgba(255, 201, 102, 0.2);--mantine-color-yellow-light-color: var(--mantine-color-yellow-0);--mantine-color-yellow-outline: var(--mantine-color-yellow-1);--mantine-color-yellow-outline-hover: rgba(255, 238, 205, 0.05);--mantine-color-orange-filled: var(--mantine-color-orange-5);--mantine-color-orange-filled-hover: var(--mantine-color-orange-6);--mantine-color-orange-light: rgba(255, 192, 120, 0.15);--mantine-color-orange-light-hover: rgba(255, 192, 120, 0.2);--mantine-color-orange-light-color: var(--mantine-color-orange-0);--mantine-color-orange-outline: var(--mantine-color-orange-1);--mantine-color-orange-outline-hover: rgba(255, 232, 204, 0.05);--app-cta-gradient: linear-gradient(90deg, var(--mantine-color-blue-9) 0%, var(--mantine-color-cyan-7) 100%);--app-color-surface: #2e2e2e;}
:root[data-mantine-color-scheme="light"], :host([data-mantine-color-scheme="light"]){--mantine-color-anchor: var(--mantine-color-text);--mantine-color-dimmed: #495057;--mantine-color-red-light: rgba(224, 40, 41, 0.1);--mantine-color-red-light-hover: rgba(224, 40, 41, 0.12);--mantine-color-red-outline-hover: rgba(224, 40, 41, 0.05);--mantine-color-violet-light: rgba(176, 9, 255, 0.1);--mantine-color-violet-light-hover: rgba(176, 9, 255, 0.12);--mantine-color-violet-outline-hover: rgba(176, 9, 255, 0.05);--mantine-color-indigo-light: rgba(45, 42, 223, 0.1);--mantine-color-indigo-light-hover: rgba(45, 42, 223, 0.12);--mantine-color-indigo-outline-hover: rgba(45, 42, 223, 0.05);--mantine-color-cyan-light: rgba(0, 194, 255, 0.1);--mantine-color-cyan-light-hover: rgba(0, 194, 255, 0.12);--mantine-color-cyan-outline-hover: rgba(0, 194, 255, 0.05);--mantine-color-green-light: rgba(63, 204, 84, 0.1);--mantine-color-green-light-hover: rgba(63, 204, 84, 0.12);--mantine-color-green-outline-hover: rgba(63, 204, 84, 0.05);--mantine-color-yellow-light: rgba(255, 169, 15, 0.1);--mantine-color-yellow-light-hover: rgba(255, 169, 15, 0.12);--mantine-color-yellow-outline-hover: rgba(255, 169, 15, 0.05);--app-color-surface: #f1f3f5;--app-cta-gradient: linear-gradient(90deg, var(--mantine-color-blue-filled) 0%, var(--mantine-color-cyan-5) 100%);}</style><style data-mantine-styles="classes">@media (max-width: 35.99375em) {.mantine-visible-from-xs {display: none !important;}}@media (min-width: 36em) {.mantine-hidden-from-xs {display: none !important;}}@media (max-width: 47.99375em) {.mantine-visible-from-sm {display: none !important;}}@media (min-width: 48em) {.mantine-hidden-from-sm {display: none !important;}}@media (max-width: 61.99375em) {.mantine-visible-from-md {display: none !important;}}@media (min-width: 62em) {.mantine-hidden-from-md {display: none !important;}}@media (max-width: 74.99375em) {.mantine-visible-from-lg {display: none !important;}}@media (min-width: 75em) {.mantine-hidden-from-lg {display: none !important;}}@media (max-width: 87.99375em) {.mantine-visible-from-xl {display: none !important;}}@media (min-width: 88em) {.mantine-hidden-from-xl {display: none !important;}}</style><script type="application/ld+json">{"@context":"https://schema.org","@type":"QAPage","mainEntity":{"@type":"Question","name":"Верстка","answerCount":2,"datePublished":"2023-06-05T10:02:25.725Z","author":{"@type":"Person","name":"Nikolai Gagarinov"},"acceptedAnswer":{"@type":"Answer","text":"В современной разработке верстальщик играет важную роль — он закладывает основу пользовательского опыта (UX) и визуальной согласованности (UI). Ошибка в отступе или разметке может разрушить впечатление от даже самого красивого дизайна.\n\n\n\n## Что такое вёрстка\n\nЭто процесс превращения дизайнерского макета в интерактивную веб-страницу, которую видит пользователь в браузере. Если дизайнер создаёт визуальный образ сайта, то верстальщик делает его «живым» — добавляет структуру, оформление, адаптивность.\n\nИменно вёрстка соединяет дизайн с программированием, превращая статичную картинку в работающий интерфейс. В коде задаётся, где располагаются элементы, какие у них цвета, отступы, шрифты, а также, как страница адаптируется под разные устройства.\n\n### Верстальщик и фронтенд-разработчик — в чём разница\n\nВерстальщик работает с HTML и CSS, иногда с базовым JavaScript, создавая визуальную оболочку сайта. Фронтенд-разработчик идёт дальше — интегрирует вёрстку с логикой приложения, API, фреймворками (React, Vue, Angular). На практике границы размыты: многие современные верстальщики постепенно переходят в фронтенд, осваивая язык программирования и работу с компонентами.\n\n## История развития вёрстки 1990-е: таблицы и первая структура\n\nПервые сайты создавались при помощи таблиц (<table>). Каждая строка и ячейка использовались для размещения элементов. Это позволяло «рисовать» структуру, но делало код тяжёлым, негибким.\n\n### 2000-е: блочная модель и CSS\n\nС появлением CSS разработчики отделили оформление от содержания. Страницы стали строиться на <div>-блоках, а внешний вид — задаваться стилями. Это упростило поддержку кода, позволило вводить стандарты W3C. Появились такие понятия, как семантика, веб-стандарты, валидность — принципы, по которым строится качественная разметка.\n\n### 2010-е: адаптивность и гибкость\n\nПоявление смартфонов изменило подход к проектированию. Страницы стали адаптироваться под разные экраны с помощью media queries. Новые технологии, такие как flexbox и CSS Grid, дали верстальщикам инструменты для построения сложных, но управляемых макетов без костылей.\n\n### Сегодня\n\nСовременная вёрстка — это не просто HTML и CSS, а целая система: дизайн-системы, UI-киты, препроцессоры, сборщики, автоматизация, тесная интеграция с JavaScript-фреймворками.\n\n## Основные технологии вёрстки\n\nВ основе любой веб-страницы лежат три кита: HTML, CSS, JavaScript. Каждый выполняет свою роль — структура, оформление, интерактивность.\n\n### HTML — структура\n\nHTML (HyperText Markup Language) задаёт «скелет» страницы. С его помощью определяется, где будет заголовок, изображение, меню, форма или подвал сайта.\n Пример простой страницы:\n\n```html\n<!DOCTYPE html><html lang="ru"> <head> <meta charset="UTF-8"> <title>Пример страницы</title> </head> <body> <h1>Добро пожаловать!</h1> <p>Это пример базовой HTML-разметки.</p> </body></html>\n```\n\nHTML поддерживает семантические теги — `<header>`, `<main>`, `<article>`, `<section>`, `<footer>` — которые помогают поисковым системам и вспомогательным технологиям (например, экранным дикторам) лучше понимать структуру страницы. Это важно для SEO, для доступности.\n\n### CSS — оформление\n\nCSS (Cascading Style Sheets) отвечает за внешний вид сайта: цвета, шрифты, отступы, сетку. Пример базового стиля:\n\n```css\nbody {\n font-family: Arial,\n sans-serif;\n color: #222;\n background-color: #fafafa;\n margin: 0;\n padding: 0;\n}\n```\n\nСовременный CSS поддерживает мощные инструменты:\n\n* **Flexbox** — удобное управление расположением элементов по осям;\n* **Grid** — гибкие сетки для сложных макетов;\n* **Transitions и animations** — плавные эффекты, динамика;\n* **Media queries** — адаптация под мобильные устройства.\n\nГлавный принцип CSS — разделение контента и оформления. Это делает код чище, облегчает поддержку: можно менять дизайн, не трогая HTML.\n\n### JavaScript — интерактивность\n\nЕсли HTML задаёт структуру, а CSS — стиль, то JavaScript добавляет жизнь. С его помощью страница реагирует на действия пользователя: открывает меню, проверяет формы, показывает всплывающие окна. JS работает с DOM (Document Object Model) — представлением структуры страницы, которое можно изменять прямо из кода. Пример:\n\n```javascript\ndocument.querySelector('h1').style.color = 'blue';\n```\n\nJavaScript делает вёрстку динамичной, превращая статические сайты в полноценные веб-приложения.\n\n## Макет сайта и подготовка к вёрстке\n\nПеред тем как начать писать код, верстальщик работает с дизайнерским макетом — визуальной моделью сайта. Макет показывает, как должна выглядеть каждая страница, какие элементы присутствуют, как они ведут себя при взаимодействии.\n\n### Где создают макеты\n\nСовременные дизайнеры работают в инструментах:\n\n* **Figma** — онлайн-платформа с возможностью совместной работы;\n* **Adobe Photoshop** — для графики и деталей интерфейса;\n* **Sketch** — популярный инструмент среди дизайнеров macOS.\n\n### Как читать макет\n\nВерстальщик анализирует структуру: где расположены блоки, какие отступы, шрифты, цвета, адаптивные состояния. Важно соблюдать принцип pixel perfect — максимальное совпадение результата с макетом.\n\n### Взаимодействие с дизайнером\n\nЭффективная коммуникация между дизайнером и верстальщиком экономит часы работы. Задача верстальщика — уточнить спорные моменты, предложить оптимальные решения, предупредить о технических ограничениях. Именно на этом этапе формируется будущий UX: качественная вёрстка не только красивая, она функциональная, логичная, быстрая в работе.\n\n## Виды вёрстки\n\nСовременная веб-вёрстка может выглядеть по-разному — всё зависит от целей проекта, используемых технологий, требований к адаптивности.\n\n### Фиксированная\n\nРазмер элементов задаётся в пикселях. Такая страница выглядит одинаково на всех устройствах, но не подстраивается под ширину экрана. Подходит для простых макетов, где важна точность расположения элементов.\n\n### Резиновая\n\nЭлементы масштабируются относительно окна браузера — за счёт процентных значений ширины и высоты. Контент «тянется», но при этом может терять пропорции. Сегодня резиновая вёрстка часто используется как промежуточный вариант.\n\n### Адаптивная\n\nАдаптивная вёрстка — стандарт современной разработки. Макет автоматически перестраивается под размер экрана с помощью media-queries. Например, меню превращается в бургер, колонки складываются в один столбец, а изображения уменьшаются без потери качества.\n\n### Валидная и кроссбраузерная\n\nВалидная вёрстка соответствует стандартам W3C, что гарантирует корректное отображение сайта в разных браузерах. Кроссбраузерность обеспечивает одинаковое поведение интерфейса в Chrome, Firefox, Safari, Edge (даже в старых версиях Internet Explorer). В идеале современный сайт совмещает адаптивность, валидность, кроссбраузерность, обеспечивая пользователю стабильный опыт независимо от устройства.\n\n## Инструменты верстальщика\n\nСовременные инструменты позволяют ускорить работу, при этом поддерживать чистый, единообразный код.\n\n### Редакторы и IDE\n\n* **VS Code** — бесплатная, гибкая среда с сотнями расширений.\n* **WebStorm** — профессиональная IDE для HTML, CSS, JS, фреймворков.\n* **Sublime Text** — лёгкий и быстрый редактор, любимый за минимализм.\n\n### Полезные плагины\n\n* **Emmet** — ускоряет набор кода с помощью сокращений (container>ul>li*3).\n* **Prettier** — автоформатирование кода.\n* **Live Server** — моментальный предпросмотр изменений в браузере.\n\n### Системы контроля версий\n\nДаже верстальщики активно используют Git и GitHub для хранения проектов, откатов, совместной работы. Это помогает отслеживать изменения и работать в команде с разработчиками.\n\n### Сборщики и препроцессоры\n\n* **Gulp, Webpack, Parcel** — автоматизируют минификацию, компиляцию стилей, обновление страниц.\n* **Sass, LESS, Stylus** — препроцессоры, расширяющие возможности CSS: переменные, вложенность, функции.\n Пример кода на Sass:\n\n```css\n$main-color: #4a90e2; body { color: $main-color; h1 { font-size: 32px; }}\n```\n\nТакой подход делает стили модульными и переиспользуемыми.\n\n\n\n## Методологии и принципы организации кода\n\nГрамотная структура кода — половина успеха любой вёрстки. Она облегчает поддержку проекта и работу в команде.\n\n### БЭМ (Блок–Элемент–Модификатор)\n\nМетодология БЭМ, разработанная в «Яндексе», помогает писать читаемые и масштабируемые CSS-классы.\nПример:\n\n**<div class="card card--highlighted"> <h2 class="card__title">Заголовок</h2></div>**\n\n**card — блок, card__title — элемент, card--highlighted — модификатор.**\n\nБлагодаря такой структуре код становится предсказуемым, независимым от контекста.\n\n## DRY и читаемость\n\nПринцип DRY (Don’t Repeat Yourself) применим и к вёрстке. Повторяющиеся стили лучше выносить в общие классы. Это сокращает CSS и повышает скорость загрузки.\n\n### Модульность и переиспользуемость\n\nХорошая вёрстка строится из модулей — небольших компонентов (карточки, кнопки, формы), которые можно вставлять в разные части сайта.\n\n### Комментарии и структура проекта\n\nКомментарии помогают ориентироваться в коде, особенно на крупных проектах. Разделение CSS по смысловым блокам (header, main, footer) делает проект предсказуемым и удобным для команды.\n\n## Проверка и тестирование вёрстки\n\nПосле завершения кодирования начинается не менее важный этап — проверка качества.\n\n### Валидация HTML и CSS\n\nСервисы W3C Validator помогают проверить код на ошибки. Валидная вёрстка гарантирует совместимость с браузерами и улучшает SEO.\n\n### Проверка адаптивности\n\nИнструменты Responsive Design Mode (в Chrome DevTools и Firefox) позволяют тестировать, как страница выглядит на разных устройствах.\n\n### Сравнение с макетом\n\nПлагины Pixel Perfect, PerfectPixel, Page Ruler позволяют наложить макет на готовую страницу, увидеть расхождения до пикселя.\n\n### Производительность и оптимизация\n\nПроверить скорость загрузки можно с помощью Lighthouse и Web Vitals. Они оценивают время отображения контента, отзывчивость интерфейса и стабильность макета. Качественная вёрстка — это баланс между визуальной точностью, оптимизацией и удобством поддержки.\n\n## Современные тенденции\n\nМир фронтенда развивается стремительно, вместе с ним меняются подходы к вёрстке. Сегодня важно не просто «сделать страницу», а обеспечить удобство, скорость, масштабируемость.\n\n### Mobile-first и responsive дизайн\n\nСовременная разработка строится по принципу mobile-first — сначала проектируется версия для смартфона, а затем расширяется до десктопа. Это логично: большинство пользователей приходят с мобильных устройств, именно там важно обеспечить удобный интерфейс и минимальные задержки загрузки.\n\n### CSS Grid и Flexbox как стандарт\n\nРаньше создание сеток требовало сложных вложений и хака с float’ами. Теперь всё проще: Grid и Flexbox стали золотым стандартом. Grid — для сложных макетов, Flexbox — для гибкого выравнивания элементов в строках и столбцах. Вместе они обеспечивают точный контроль над структурой.\n\n### CSS Variables и кастомные свойства\n\nКастомные свойства (--color-primary, --font-size-base) делают код динамичным. Изменив значение переменной, можно мгновенно поменять цветовую схему или тему сайта. Это особенно актуально для тёмного режима и дизайн-систем.\n\n### UI-фреймворки и библиотеки\n\nБыстрая разработка невозможна без готовых решений. Самые популярные инструменты:\n\n* **Bootstrap** — проверенная временем библиотека компонентов;\n* **Tailwind CSS** — утилитарный фреймворк с фокусом на кастомизацию;\n* **Material UI** — визуальный язык от Google, интегрируемый с React.\n\nUI-фреймворки экономят время, но важно не терять индивидуальность дизайна.\n\n### Интерактивная вёрстка\n\nГраница между верстальщиком и фронтендером всё больше стирается. Многие проекты требуют базовых знаний React или Vue — библиотек, которые позволяют создавать динамичные интерфейсы без перезагрузки страниц. Современный верстальщик должен не только знать CSS, но и понимать, как компоненты работают в связке с JavaScript.\n\n## Ошибки и советы\n\n### Типичные промахи\n\n1. **Неверная вложенность элементов.** Ошибка в структуре HTML ломает вёрстку на уровне браузера.\n2. **Избыточные inline-стили.** Они усложняют поддержку, противоречат принципам разделения кода.\n3. **Отсутствие alt у изображений.** Это мешает SEO и доступности.\n4. **Жёсткие размеры без адаптации.** Страница «сыплется» на мобильных устройствах.\n\n### Советы по оптимизации\n\n* Используйте относительные единицы (em, %, rem) — они позволяют масштабировать интерфейс.\n* Минимизируйте и объединяйте CSS-файлы для ускорения загрузки.\n* Следите за иерархией заголовков (h1–h6) — это важно для SEO и логики восприятия.\n* Структурируйте проект: отдельные папки для стилей, изображений, скриптов.\n\n### Оптимизация под производительность\n\nВёрстка напрямую влияет на скорость сайта. Чем меньше CSS и запросов к серверу — тем быстрее откроется страница. Инструменты вроде Lighthouse помогают оценить и улучшить показатели.\n\n\n\n## Профессия верстальщика\n\nВёрстка — одна из самых доступных точек входа в IT, особенно для тех, кто только начинает путь в разработке.\n\n### Кто такой верстальщик\n\nЭто специалист, который создаёт HTML/CSS-код на основе дизайнерских макетов. Он отвечает за визуальную часть сайта, совместимость с браузерами, адаптивность.\n\n### Необходимые навыки\n\n* знание **HTML5** и **CSS3**;\n* основы **JavaScript**;\n* принципы адаптивного и кроссбраузерного дизайна;\n* умение работать с инструментами (Git, Figma, DevTools).\n\n### Карьера и перспективы\n\nМожно расти в нескольких направлениях:\n\n* **Frontend-разработка** — логичное продолжение пути;\n* **UI-инженерия** — специализация на интерфейсах и анимациях;\n* **Web performance** — оптимизация скорости и качества сайтов.\n\nСпрос на внимательных специалистов с сильным чувством структуры стабильно высок: компании нуждаются в разработчиках, которые умеют превращать дизайн в чистый, гибкий код.\n\n### Обучение\n\nОнлайн-школы (Hexlet, Skillfactory, Coursera) предлагают курсы, где студенты шаг за шагом осваивают HTML, CSS, JavaScript на практике. Главное — не просто слушать лекции, а верстать реальные проекты, анализировать ошибки, искать способы улучшить код.\n\n## Заключение\n\nВёрстка — это мост между идеей и её воплощением. Она делает дизайн доступным пользователю, а интерфейс — удобным и красивым. Современный верстальщик сочетает точность инженера и вкус дизайнера. В мире разработки нет мелочей: каждый пиксель важен. Поэтому, если вы только начинаете путь в IT — начните с вёрстки. Она научит вас логике, внимательности, дисциплине кода — качествам хорошего программиста.\n","datePublished":"2025-11-24T19:15:25.564Z","upvoteCount":1,"author":{"@type":"Person","name":"Nikolai Gagarinov"},"url":"https://ru.hexlet.io/qna/glossary/questions/chto-takoe-verstka#answer-5219"},"suggestedAnswer":[{"@type":"Answer","text":"Верстка - это процесс создания макета страницы или документа. В веб-разработке верстка означает создание HTML-кода и CSS-стилей, которые определяют структуру и внешний вид веб-страницы. После верстки страница может быть отображена в браузере и проверена на наличие ошибок.","datePublished":"2023-11-16T13:42:25.844Z","upvoteCount":0,"author":{"@type":"Person","name":"Елена Редькина"},"url":"https://ru.hexlet.io/qna/glossary/questions/chto-takoe-verstka#answer-3093"}]}}</script><div style="--container-size:var(--container-size-lg);margin-top:var(--mantine-spacing-xl);height:100%" class="m_7485cace mantine-Container-root" data-size="lg" data-strategy="block"><script type="application/ld+json">{"@context":"https://schema.org","@type":"BreadcrumbList","itemListElement":[{"position":1,"@type":"ListItem","item":{"@id":"/qna","name":"Вопросы и ответы"}},{"position":2,"@type":"ListItem","item":{"@id":"/qna/glossary/questions","name":"Глоссарий"}},{"position":3,"@type":"ListItem","item":{"@id":"/qna/glossary/questions/chto-takoe-verstka","name":"Верстка"}}]}</script><div style="margin-bottom:var(--mantine-spacing-xs)" class="m_8b3717df mantine-Breadcrumbs-root"><a style="--text-fz:var(--mantine-font-size-sm);--text-lh:var(--mantine-line-height-sm);white-space:normal;color:inherit" class="mantine-focus-auto m_849cf0da m_f678d540 mantine-Breadcrumbs-breadcrumb m_b6d8b162 mantine-Text-root mantine-Anchor-root" data-size="sm" data-underline="hover" href="/"><div style="color:inherit" class="m_4451eb3a mantine-Center-root"><svg xmlns="http://www.w3.org/2000/svg" width="15" height="15" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" class="tabler-icon tabler-icon-home-link "><path d="M20.085 11.085l-8.085 -8.085l-9 9h2v7a2 2 0 0 0 2 2h4.5"></path><path d="M9 21v-6a2 2 0 0 1 2 -2h2a2 2 0 0 1 1.807 1.143"></path><path d="M20 21a1 1 0 1 0 2 0a1 1 0 1 0 -2 0"></path><path d="M20 16a1 1 0 1 0 2 0a1 1 0 1 0 -2 0"></path><path d="M15 19a1 1 0 1 0 2 0a1 1 0 1 0 -2 0"></path><path d="M21 16l-5 3l5 2"></path></svg></div></a><div class="m_3b8f2208 mantine-Breadcrumbs-separator">/</div><a style="--text-fz:var(--mantine-font-size-sm);--text-lh:var(--mantine-line-height-sm);white-space:normal;color:inherit" class="mantine-focus-auto m_849cf0da m_f678d540 mantine-Breadcrumbs-breadcrumb m_b6d8b162 mantine-Text-root mantine-Anchor-root" data-size="sm" data-underline="hover" href="/qna">Вопросы и ответы</a><div class="m_3b8f2208 mantine-Breadcrumbs-separator">/</div><a style="--text-fz:var(--mantine-font-size-sm);--text-lh:var(--mantine-line-height-sm);white-space:normal;color:inherit" class="mantine-focus-auto m_849cf0da m_f678d540 mantine-Breadcrumbs-breadcrumb m_b6d8b162 mantine-Text-root mantine-Anchor-root" data-size="sm" data-underline="hover" href="/qna/glossary/questions">Глоссарий</a><div class="m_3b8f2208 mantine-Breadcrumbs-separator">/</div><p style="--text-fz:var(--mantine-font-size-sm);--text-lh:var(--mantine-line-height-sm);white-space:normal;color:var(--mantine-color-dimmed)" class="mantine-focus-auto m_f678d540 mantine-Breadcrumbs-breadcrumb m_b6d8b162 mantine-Text-root" data-size="sm">Верстка</p></div><style data-mantine-styles="inline">.__m__-_R_eub_{margin-bottom:var(--mantine-spacing-xs);}@media(min-width: 36em){.__m__-_R_eub_{margin-bottom:var(--mantine-spacing-xs);}}</style><div style="--group-gap:var(--mantine-spacing-md);--group-align:center;--group-justify:space-between;--group-wrap:wrap" class="m_4081bf90 mantine-Group-root __m__-_R_eub_"><style data-mantine-styles="inline">.__m__-_R_deub_{width:100%;}@media(min-width: 36em){.__m__-_R_deub_{width:70%;}}@media(min-width: 75em){.__m__-_R_deub_{width:75%;}}</style><div class="__m__-_R_deub_"><div style="--group-gap:var(--mantine-spacing-md);--group-align:center;--group-justify:start;--group-wrap:nowrap" class="m_4081bf90 mantine-Group-root"><h1 style="--title-fw:var(--mantine-h1-font-weight);--title-lh:var(--mantine-h1-line-height);--title-fz:var(--mantine-h1-font-size)" class="m_8a5d1357 mantine-Title-root" data-order="1">Верстка</h1></div></div></div><style data-mantine-styles="inline">.__m__-_R_iub_{--grid-gutter:var(--mantine-spacing-md);}</style><div class="m_410352e9 mantine-Grid-root __m__-_R_iub_"><div class="m_dee7bd2f mantine-Grid-inner"><style data-mantine-styles="inline">.__m__-_R_3diub_{--col-flex-grow:auto;--col-flex-basis:100%;--col-max-width:100%;}@media(min-width: 48em){.__m__-_R_3diub_{--col-flex-grow:auto;--col-flex-basis:83.33333333333334%;--col-max-width:83.33333333333334%;}}@media(min-width: 62em){.__m__-_R_3diub_{--col-flex-grow:auto;--col-flex-basis:66.66666666666667%;--col-max-width:66.66666666666667%;}}</style><div class="m_96bdd299 mantine-Grid-col __m__-_R_3diub_"><div style="--group-gap:var(--mantine-spacing-md);--group-align:center;--group-justify:flex-start;--group-wrap:wrap;margin-bottom:var(--mantine-spacing-lg)" class="m_4081bf90 mantine-Group-root"></div><div style="--group-gap:var(--mantine-spacing-md);--group-align:center;--group-justify:flex-start;--group-wrap:wrap;margin-bottom:var(--mantine-spacing-xl);font-size:var(--mantine-font-size-sm)" class="m_4081bf90 mantine-Group-root"><div style="--group-gap:calc(0.25rem * var(--mantine-scale));--group-align:center;--group-justify:flex-start;--group-wrap:wrap;margin-inline-start:auto" class="m_4081bf90 mantine-Group-root"><svg xmlns="http://www.w3.org/2000/svg" width="16" height="16" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" class="tabler-icon tabler-icon-calendar "><path d="M4 7a2 2 0 0 1 2 -2h12a2 2 0 0 1 2 2v12a2 2 0 0 1 -2 2h-12a2 2 0 0 1 -2 -2v-12"></path><path d="M16 3v4"></path><path d="M8 3v4"></path><path d="M4 11h16"></path><path d="M11 15h1"></path><path d="M12 15v3"></path></svg><p class="mantine-focus-auto m_b6d8b162 mantine-Text-root" data-inherit="true">3 года назад</p></div><div style="--group-gap:calc(0.25rem * var(--mantine-scale));--group-align:center;--group-justify:flex-start;--group-wrap:wrap" class="m_4081bf90 mantine-Group-root"><svg xmlns="http://www.w3.org/2000/svg" width="16" height="16" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" class="tabler-icon tabler-icon-user "><path d="M8 7a4 4 0 1 0 8 0a4 4 0 0 0 -8 0"></path><path d="M6 21v-2a4 4 0 0 1 4 -4h4a4 4 0 0 1 4 4v2"></path></svg><p class="mantine-focus-auto m_b6d8b162 mantine-Text-root" data-inherit="true">Nikolai Gagarinov</p></div></div><div role="link" tabindex="0" style="cursor:pointer"><button style="display:block;width:100%" class="mantine-focus-auto m_87cf2631 mantine-UnstyledButton-root" type="button" aria-label="Присоединяйтесь к нашему Telegram-сообществу"><div style="background-color:light-dark(var(--mantine-color-gray-1), var(--mantine-color-dark-6));margin-block:var(--mantine-spacing-xs)" class="m_e615b15f mantine-Card-root m_1b7284a3 mantine-Paper-root"><div style="--group-gap:var(--mantine-spacing-md);--group-align:center;--group-justify:flex-start;--group-wrap:wrap" class="m_4081bf90 mantine-Group-root"><div style="--ti-bg:transparent;--ti-color:var(--mantine-color-indigo-light-color);--ti-bd:calc(0.0625rem * var(--mantine-scale)) solid transparent;margin-inline-end:auto;color:inherit" class="m_7341320d mantine-ThemeIcon-root" data-variant="transparent"><svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="1.2" stroke-linecap="round" stroke-linejoin="round" class="tabler-icon tabler-icon-brand-telegram "><path d="M15 10l-4 4l6 6l4 -16l-18 7l4 2l2 6l3 -4"></path></svg></div>Присоединяйтесь к нашему Telegram-сообществу</div></div></button></div><h2 style="--title-fw:var(--mantine-h2-font-weight);--title-lh:var(--mantine-h2-line-height);--title-fz:var(--mantine-h2-font-size);margin-block:var(--mantine-spacing-xl)" class="m_8a5d1357 mantine-Title-root" data-order="2">Ответы</h2><div style="margin-bottom:var(--mantine-spacing-xl);padding:var(--mantine-spacing-lg)" class="m_e615b15f mantine-Card-root m_1b7284a3 mantine-Paper-root" data-with-border="true" id="answer-5219"><div style="--group-gap:calc(1.125rem * var(--mantine-scale));--group-align:stretch;--group-justify:flex-start;--group-wrap:nowrap" class="m_4081bf90 mantine-Group-root"><div style="--stack-gap:var(--mantine-spacing-md);--stack-align:stretch;--stack-justify:flex-start;font-size:var(--mantine-font-size-h1);font-weight:lighter;text-align:center" class="m_6d731127 mantine-Stack-root">1<a style="color:inherit" class="mantine-focus-auto m_849cf0da m_b6d8b162 mantine-Text-root mantine-Anchor-root" data-underline="hover" href="/qna/glossary/questions/chto-takoe-verstka/answers/5219/vote"><div style="--ti-bg:transparent;--ti-color:var(--mantine-color-indigo-light-color);--ti-bd:calc(0.0625rem * var(--mantine-scale)) solid transparent;color:inherit" class="m_7341320d mantine-ThemeIcon-root" data-variant="transparent"><svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" class="tabler-icon tabler-icon-thumb-up "><path d="M7 11v8a1 1 0 0 1 -1 1h-2a1 1 0 0 1 -1 -1v-7a1 1 0 0 1 1 -1h3a4 4 0 0 0 4 -4v-1a2 2 0 0 1 4 0v5h3a2 2 0 0 1 2 2l-1 5a2 3 0 0 1 -2 2h-7a3 3 0 0 1 -3 -3"></path></svg></div></a><div style="--ti-bg:transparent;--ti-color:var(--mantine-color-indigo-light-color);--ti-bd:calc(0.0625rem * var(--mantine-scale)) solid transparent;color:inherit" class="m_7341320d mantine-ThemeIcon-root" data-variant="transparent"><svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" class="tabler-icon tabler-icon-check "><path d="M5 12l5 5l10 -10"></path></svg></div></div><div style="--stack-gap:var(--mantine-spacing-md);--stack-align:stretch;--stack-justify:flex-start;width:100%;min-width:0rem" class="m_6d731127 mantine-Stack-root"><div style="margin-bottom:auto" class="m_d08caa0 mantine-Typography-root"><p>В современной разработке верстальщик играет важную роль — он закладывает основу пользовательского опыта (UX) и визуальной согласованности (UI). Ошибка в отступе или разметке может разрушить впечатление от даже самого красивого дизайна.</p>
<p><img style="--image-object-fit:contain;width:auto" class="m_9e117634 mantine-Image-root" src="https://cdn6.hexlet.io/qSGDUzrLDhgb.png" alt="QSGDUzrLDhgb image" loading="lazy"/></p>
<h2 id="heading-2-1">Что такое вёрстка</h2>
<p>Это процесс превращения дизайнерского макета в интерактивную веб-страницу, которую видит пользователь в браузере. Если дизайнер создаёт визуальный образ сайта, то верстальщик делает его «живым» — добавляет структуру, оформление, адаптивность.</p>
<p>Именно вёрстка соединяет дизайн с программированием, превращая статичную картинку в работающий интерфейс. В коде задаётся, где располагаются элементы, какие у них цвета, отступы, шрифты, а также, как страница адаптируется под разные устройства.</p>
<h3 id="heading-3-2">Верстальщик и фронтенд-разработчик — в чём разница</h3>
<p>Верстальщик работает с HTML и CSS, иногда с базовым JavaScript, создавая визуальную оболочку сайта. Фронтенд-разработчик идёт дальше — интегрирует вёрстку с логикой приложения, API, фреймворками (React, Vue, Angular). На практике границы размыты: многие современные верстальщики постепенно переходят в фронтенд, осваивая язык программирования и работу с компонентами.</p>
<h2 id="heading-2-3">История развития вёрстки 1990-е: таблицы и первая структура</h2>
<p>Первые сайты создавались при помощи таблиц (<!-- -->). Каждая строка и ячейка использовались для размещения элементов. Это позволяло «рисовать» структуру, но делало код тяжёлым, негибким.</p>
<h3 id="heading-3-4">2000-е: блочная модель и CSS</h3>
<p>С появлением CSS разработчики отделили оформление от содержания. Страницы стали строиться на <!-- -->-блоках, а внешний вид — задаваться стилями. Это упростило поддержку кода, позволило вводить стандарты W3C. Появились такие понятия, как семантика, веб-стандарты, валидность — принципы, по которым строится качественная разметка.</p>
<h3 id="heading-3-5">2010-е: адаптивность и гибкость</h3>
<p>Появление смартфонов изменило подход к проектированию. Страницы стали адаптироваться под разные экраны с помощью media queries. Новые технологии, такие как flexbox и CSS Grid, дали верстальщикам инструменты для построения сложных, но управляемых макетов без костылей.</p>
<h3 id="heading-3-6">Сегодня</h3>
<p>Современная вёрстка — это не просто HTML и CSS, а целая система: дизайн-системы, UI-киты, препроцессоры, сборщики, автоматизация, тесная интеграция с JavaScript-фреймворками.</p>
<h2 id="heading-2-7">Основные технологии вёрстки</h2>
<p>В основе любой веб-страницы лежат три кита: HTML, CSS, JavaScript. Каждый выполняет свою роль — структура, оформление, интерактивность.</p>
<h3 id="heading-3-8">HTML — структура</h3>
<p>HTML (HyperText Markup Language) задаёт «скелет» страницы. С его помощью определяется, где будет заголовок, изображение, меню, форма или подвал сайта.
Пример простой страницы:</p>
<div style="margin-bottom:var(--mantine-spacing-lg)" class="m_e597c321 mantine-CodeHighlight-codeHighlight" dir="ltr"><div class="m_be7e9c9c mantine-CodeHighlight-controls"><button style="--ai-bg:transparent;--ai-hover:transparent;--ai-color:inherit;--ai-bd:none" class="mantine-focus-auto mantine-active m_d498bab7 mantine-CodeHighlight-control m_8d3f4000 mantine-ActionIcon-root m_87cf2631 mantine-UnstyledButton-root" data-variant="none" type="button" aria-label="Copy code"><span class="m_8d3afb97 mantine-ActionIcon-icon"><svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" stroke-width="2" stroke="currentColor" fill="none" stroke-linecap="round" stroke-linejoin="round"><path stroke="none" d="M0 0h24v24H0z" fill="none"></path><path d="M8 8m0 2a2 2 0 0 1 2 -2h8a2 2 0 0 1 2 2v8a2 2 0 0 1 -2 2h-8a2 2 0 0 1 -2 -2z"></path><path d="M16 8v-2a2 2 0 0 0 -2 -2h-8a2 2 0 0 0 -2 2v8a2 2 0 0 0 2 2h2"></path></svg></span></button></div><div style="--scrollarea-scrollbar-size:calc(0.25rem * var(--mantine-scale));--sa-corner-width:0px;--sa-corner-height:0px" class="m_f744fd40 mantine-CodeHighlight-scrollarea m_d57069b5 mantine-ScrollArea-root" dir="ltr"><div style="overflow-x:hidden;overflow-y:hidden;overscroll-behavior-inline:none" class="m_c0783ff9 mantine-ScrollArea-viewport" data-scrollbars="xy"><div class="m_b1336c6 mantine-ScrollArea-content"><pre class="m_2c47c4fd mantine-CodeHighlight-pre" style="padding:0"><code class="m_5caae6d3 mantine-CodeHighlight-code"><!DOCTYPE html><html lang="ru"> <head> <meta charset="UTF-8"> <title>Пример страницы</title> </head> <body> <h1>Добро пожаловать!</h1> <p>Это пример базовой HTML-разметки.</p> </body></html></code></pre></div></div></div><button class="mantine-focus-auto m_c9378bc2 mantine-CodeHighlight-showCodeButton m_87cf2631 mantine-UnstyledButton-root" data-hidden="true" type="button">Expand code</button></div>
<p>HTML поддерживает семантические теги — <code style="margin-bottom:var(--mantine-spacing-lg)" class="m_dfe9c588 mantine-InlineCodeHighlight-inlineCodeHighlight m_e597c321 mantine-CodeHighlight-codeHighlight m_dfe9c588 mantine-InlineCodeHighlight-inlineCodeHighlight"><header></code>, <code style="margin-bottom:var(--mantine-spacing-lg)" class="m_dfe9c588 mantine-InlineCodeHighlight-inlineCodeHighlight m_e597c321 mantine-CodeHighlight-codeHighlight m_dfe9c588 mantine-InlineCodeHighlight-inlineCodeHighlight"><main></code>, <code style="margin-bottom:var(--mantine-spacing-lg)" class="m_dfe9c588 mantine-InlineCodeHighlight-inlineCodeHighlight m_e597c321 mantine-CodeHighlight-codeHighlight m_dfe9c588 mantine-InlineCodeHighlight-inlineCodeHighlight"><article></code>, <code style="margin-bottom:var(--mantine-spacing-lg)" class="m_dfe9c588 mantine-InlineCodeHighlight-inlineCodeHighlight m_e597c321 mantine-CodeHighlight-codeHighlight m_dfe9c588 mantine-InlineCodeHighlight-inlineCodeHighlight"><section></code>, <code style="margin-bottom:var(--mantine-spacing-lg)" class="m_dfe9c588 mantine-InlineCodeHighlight-inlineCodeHighlight m_e597c321 mantine-CodeHighlight-codeHighlight m_dfe9c588 mantine-InlineCodeHighlight-inlineCodeHighlight"><footer></code> — которые помогают поисковым системам и вспомогательным технологиям (например, экранным дикторам) лучше понимать структуру страницы. Это важно для SEO, для доступности.</p>
<h3 id="heading-3-9">CSS — оформление</h3>
<p>CSS (Cascading Style Sheets) отвечает за внешний вид сайта: цвета, шрифты, отступы, сетку. Пример базового стиля:</p>
<div style="margin-bottom:var(--mantine-spacing-lg)" class="m_e597c321 mantine-CodeHighlight-codeHighlight" dir="ltr"><div class="m_be7e9c9c mantine-CodeHighlight-controls"><button style="--ai-bg:transparent;--ai-hover:transparent;--ai-color:inherit;--ai-bd:none" class="mantine-focus-auto mantine-active m_d498bab7 mantine-CodeHighlight-control m_8d3f4000 mantine-ActionIcon-root m_87cf2631 mantine-UnstyledButton-root" data-variant="none" type="button" aria-label="Copy code"><span class="m_8d3afb97 mantine-ActionIcon-icon"><svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" stroke-width="2" stroke="currentColor" fill="none" stroke-linecap="round" stroke-linejoin="round"><path stroke="none" d="M0 0h24v24H0z" fill="none"></path><path d="M8 8m0 2a2 2 0 0 1 2 -2h8a2 2 0 0 1 2 2v8a2 2 0 0 1 -2 2h-8a2 2 0 0 1 -2 -2z"></path><path d="M16 8v-2a2 2 0 0 0 -2 -2h-8a2 2 0 0 0 -2 2v8a2 2 0 0 0 2 2h2"></path></svg></span></button></div><div style="--scrollarea-scrollbar-size:calc(0.25rem * var(--mantine-scale));--sa-corner-width:0px;--sa-corner-height:0px" class="m_f744fd40 mantine-CodeHighlight-scrollarea m_d57069b5 mantine-ScrollArea-root" dir="ltr"><div style="overflow-x:hidden;overflow-y:hidden;overscroll-behavior-inline:none" class="m_c0783ff9 mantine-ScrollArea-viewport" data-scrollbars="xy"><div class="m_b1336c6 mantine-ScrollArea-content"><pre class="m_2c47c4fd mantine-CodeHighlight-pre" style="padding:0"><code class="m_5caae6d3 mantine-CodeHighlight-code">body {
font-family: Arial,
sans-serif;
color: #222;
background-color: #fafafa;
margin: 0;
padding: 0;
}</code></pre></div></div></div><button class="mantine-focus-auto m_c9378bc2 mantine-CodeHighlight-showCodeButton m_87cf2631 mantine-UnstyledButton-root" data-hidden="true" type="button">Expand code</button></div>
<p>Современный CSS поддерживает мощные инструменты:</p>
<ul>
<li><strong>Flexbox</strong> — удобное управление расположением элементов по осям;</li>
<li><strong>Grid</strong> — гибкие сетки для сложных макетов;</li>
<li><strong>Transitions и animations</strong> — плавные эффекты, динамика;</li>
<li><strong>Media queries</strong> — адаптация под мобильные устройства.</li>
</ul>
<p>Главный принцип CSS — разделение контента и оформления. Это делает код чище, облегчает поддержку: можно менять дизайн, не трогая HTML.</p>
<h3 id="heading-3-10">JavaScript — интерактивность</h3>
<p>Если HTML задаёт структуру, а CSS — стиль, то JavaScript добавляет жизнь. С его помощью страница реагирует на действия пользователя: открывает меню, проверяет формы, показывает всплывающие окна. JS работает с DOM (Document Object Model) — представлением структуры страницы, которое можно изменять прямо из кода. Пример:</p>
<div style="margin-bottom:var(--mantine-spacing-lg)" class="m_e597c321 mantine-CodeHighlight-codeHighlight" dir="ltr"><div class="m_be7e9c9c mantine-CodeHighlight-controls"><button style="--ai-bg:transparent;--ai-hover:transparent;--ai-color:inherit;--ai-bd:none" class="mantine-focus-auto mantine-active m_d498bab7 mantine-CodeHighlight-control m_8d3f4000 mantine-ActionIcon-root m_87cf2631 mantine-UnstyledButton-root" data-variant="none" type="button" aria-label="Copy code"><span class="m_8d3afb97 mantine-ActionIcon-icon"><svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" stroke-width="2" stroke="currentColor" fill="none" stroke-linecap="round" stroke-linejoin="round"><path stroke="none" d="M0 0h24v24H0z" fill="none"></path><path d="M8 8m0 2a2 2 0 0 1 2 -2h8a2 2 0 0 1 2 2v8a2 2 0 0 1 -2 2h-8a2 2 0 0 1 -2 -2z"></path><path d="M16 8v-2a2 2 0 0 0 -2 -2h-8a2 2 0 0 0 -2 2v8a2 2 0 0 0 2 2h2"></path></svg></span></button></div><div style="--scrollarea-scrollbar-size:calc(0.25rem * var(--mantine-scale));--sa-corner-width:0px;--sa-corner-height:0px" class="m_f744fd40 mantine-CodeHighlight-scrollarea m_d57069b5 mantine-ScrollArea-root" dir="ltr"><div style="overflow-x:hidden;overflow-y:hidden;overscroll-behavior-inline:none" class="m_c0783ff9 mantine-ScrollArea-viewport" data-scrollbars="xy"><div class="m_b1336c6 mantine-ScrollArea-content"><pre class="m_2c47c4fd mantine-CodeHighlight-pre" style="padding:0"><code class="m_5caae6d3 mantine-CodeHighlight-code">document.querySelector('h1').style.color = 'blue';</code></pre></div></div></div><button class="mantine-focus-auto m_c9378bc2 mantine-CodeHighlight-showCodeButton m_87cf2631 mantine-UnstyledButton-root" data-hidden="true" type="button">Expand code</button></div>
<p>JavaScript делает вёрстку динамичной, превращая статические сайты в полноценные веб-приложения.</p>
<h2 id="heading-2-11">Макет сайта и подготовка к вёрстке</h2>
<p>Перед тем как начать писать код, верстальщик работает с дизайнерским макетом — визуальной моделью сайта. Макет показывает, как должна выглядеть каждая страница, какие элементы присутствуют, как они ведут себя при взаимодействии.</p>
<h3 id="heading-3-12">Где создают макеты</h3>
<p>Современные дизайнеры работают в инструментах:</p>
<ul>
<li><strong>Figma</strong> — онлайн-платформа с возможностью совместной работы;</li>
<li><strong>Adobe Photoshop</strong> — для графики и деталей интерфейса;</li>
<li><strong>Sketch</strong> — популярный инструмент среди дизайнеров macOS.</li>
</ul>
<h3 id="heading-3-13">Как читать макет</h3>
<p>Верстальщик анализирует структуру: где расположены блоки, какие отступы, шрифты, цвета, адаптивные состояния. Важно соблюдать принцип pixel perfect — максимальное совпадение результата с макетом.</p>
<h3 id="heading-3-14">Взаимодействие с дизайнером</h3>
<p>Эффективная коммуникация между дизайнером и верстальщиком экономит часы работы. Задача верстальщика — уточнить спорные моменты, предложить оптимальные решения, предупредить о технических ограничениях. Именно на этом этапе формируется будущий UX: качественная вёрстка не только красивая, она функциональная, логичная, быстрая в работе.</p>
<h2 id="heading-2-15">Виды вёрстки</h2>
<p>Современная веб-вёрстка может выглядеть по-разному — всё зависит от целей проекта, используемых технологий, требований к адаптивности.</p>
<h3 id="heading-3-16">Фиксированная</h3>
<p>Размер элементов задаётся в пикселях. Такая страница выглядит одинаково на всех устройствах, но не подстраивается под ширину экрана. Подходит для простых макетов, где важна точность расположения элементов.</p>
<h3 id="heading-3-17">Резиновая</h3>
<p>Элементы масштабируются относительно окна браузера — за счёт процентных значений ширины и высоты. Контент «тянется», но при этом может терять пропорции. Сегодня резиновая вёрстка часто используется как промежуточный вариант.</p>
<h3 id="heading-3-18">Адаптивная</h3>
<p>Адаптивная вёрстка — стандарт современной разработки. Макет автоматически перестраивается под размер экрана с помощью media-queries. Например, меню превращается в бургер, колонки складываются в один столбец, а изображения уменьшаются без потери качества.</p>
<h3 id="heading-3-19">Валидная и кроссбраузерная</h3>
<p>Валидная вёрстка соответствует стандартам W3C, что гарантирует корректное отображение сайта в разных браузерах. Кроссбраузерность обеспечивает одинаковое поведение интерфейса в Chrome, Firefox, Safari, Edge (даже в старых версиях Internet Explorer). В идеале современный сайт совмещает адаптивность, валидность, кроссбраузерность, обеспечивая пользователю стабильный опыт независимо от устройства.</p>
<h2 id="heading-2-20">Инструменты верстальщика</h2>
<p>Современные инструменты позволяют ускорить работу, при этом поддерживать чистый, единообразный код.</p>
<h3 id="heading-3-21">Редакторы и IDE</h3>
<ul>
<li><strong>VS Code</strong> — бесплатная, гибкая среда с сотнями расширений.</li>
<li><strong>WebStorm</strong> — профессиональная IDE для HTML, CSS, JS, фреймворков.</li>
<li><strong>Sublime Text</strong> — лёгкий и быстрый редактор, любимый за минимализм.</li>
</ul>
<h3 id="heading-3-22">Полезные плагины</h3>
<ul>
<li><strong>Emmet</strong> — ускоряет набор кода с помощью сокращений (container>ul>li*3).</li>
<li><strong>Prettier</strong> — автоформатирование кода.</li>
<li><strong>Live Server</strong> — моментальный предпросмотр изменений в браузере.</li>
</ul>
<h3 id="heading-3-23">Системы контроля версий</h3>
<p>Даже верстальщики активно используют Git и GitHub для хранения проектов, откатов, совместной работы. Это помогает отслеживать изменения и работать в команде с разработчиками.</p>
<h3 id="heading-3-24">Сборщики и препроцессоры</h3>
<ul>
<li><strong>Gulp, Webpack, Parcel</strong> — автоматизируют минификацию, компиляцию стилей, обновление страниц.</li>
<li><strong>Sass, LESS, Stylus</strong> — препроцессоры, расширяющие возможности CSS: переменные, вложенность, функции.
Пример кода на Sass:</li>
</ul>
<div style="margin-bottom:var(--mantine-spacing-lg)" class="m_e597c321 mantine-CodeHighlight-codeHighlight" dir="ltr"><div class="m_be7e9c9c mantine-CodeHighlight-controls"><button style="--ai-bg:transparent;--ai-hover:transparent;--ai-color:inherit;--ai-bd:none" class="mantine-focus-auto mantine-active m_d498bab7 mantine-CodeHighlight-control m_8d3f4000 mantine-ActionIcon-root m_87cf2631 mantine-UnstyledButton-root" data-variant="none" type="button" aria-label="Copy code"><span class="m_8d3afb97 mantine-ActionIcon-icon"><svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" stroke-width="2" stroke="currentColor" fill="none" stroke-linecap="round" stroke-linejoin="round"><path stroke="none" d="M0 0h24v24H0z" fill="none"></path><path d="M8 8m0 2a2 2 0 0 1 2 -2h8a2 2 0 0 1 2 2v8a2 2 0 0 1 -2 2h-8a2 2 0 0 1 -2 -2z"></path><path d="M16 8v-2a2 2 0 0 0 -2 -2h-8a2 2 0 0 0 -2 2v8a2 2 0 0 0 2 2h2"></path></svg></span></button></div><div style="--scrollarea-scrollbar-size:calc(0.25rem * var(--mantine-scale));--sa-corner-width:0px;--sa-corner-height:0px" class="m_f744fd40 mantine-CodeHighlight-scrollarea m_d57069b5 mantine-ScrollArea-root" dir="ltr"><div style="overflow-x:hidden;overflow-y:hidden;overscroll-behavior-inline:none" class="m_c0783ff9 mantine-ScrollArea-viewport" data-scrollbars="xy"><div class="m_b1336c6 mantine-ScrollArea-content"><pre class="m_2c47c4fd mantine-CodeHighlight-pre" style="padding:0"><code class="m_5caae6d3 mantine-CodeHighlight-code">$main-color: #4a90e2; body { color: $main-color; h1 { font-size: 32px; }}</code></pre></div></div></div><button class="mantine-focus-auto m_c9378bc2 mantine-CodeHighlight-showCodeButton m_87cf2631 mantine-UnstyledButton-root" data-hidden="true" type="button">Expand code</button></div>
<p>Такой подход делает стили модульными и переиспользуемыми.</p>
<p><img style="--image-object-fit:contain;width:auto" class="m_9e117634 mantine-Image-root" src="https://cdn6.hexlet.io/z8DqOoUve91N.png" alt="Z8DqOoUve91N image" loading="lazy"/></p>
<h2 id="heading-2-25">Методологии и принципы организации кода</h2>
<p>Грамотная структура кода — половина успеха любой вёрстки. Она облегчает поддержку проекта и работу в команде.</p>
<h3 id="heading-3-26">БЭМ (Блок–Элемент–Модификатор)</h3>
<p>Методология БЭМ, разработанная в «Яндексе», помогает писать читаемые и масштабируемые CSS-классы.
Пример:</p>
<p><strong> <!-- -->Заголовок</strong></p>
<p><strong>card — блок, card__title — элемент, card--highlighted — модификатор.</strong></p>
<p>Благодаря такой структуре код становится предсказуемым, независимым от контекста.</p>
<h2 id="heading-2-27">DRY и читаемость</h2>
<p>Принцип DRY (Don’t Repeat Yourself) применим и к вёрстке. Повторяющиеся стили лучше выносить в общие классы. Это сокращает CSS и повышает скорость загрузки.</p>
<h3 id="heading-3-28">Модульность и переиспользуемость</h3>
<p>Хорошая вёрстка строится из модулей — небольших компонентов (карточки, кнопки, формы), которые можно вставлять в разные части сайта.</p>
<h3 id="heading-3-29">Комментарии и структура проекта</h3>
<p>Комментарии помогают ориентироваться в коде, особенно на крупных проектах. Разделение CSS по смысловым блокам (header, main, footer) делает проект предсказуемым и удобным для команды.</p>
<h2 id="heading-2-30">Проверка и тестирование вёрстки</h2>
<p>После завершения кодирования начинается не менее важный этап — проверка качества.</p>
<h3 id="heading-3-31">Валидация HTML и CSS</h3>
<p>Сервисы W3C Validator помогают проверить код на ошибки. Валидная вёрстка гарантирует совместимость с браузерами и улучшает SEO.</p>
<h3 id="heading-3-32">Проверка адаптивности</h3>
<p>Инструменты Responsive Design Mode (в Chrome DevTools и Firefox) позволяют тестировать, как страница выглядит на разных устройствах.</p>
<h3 id="heading-3-33">Сравнение с макетом</h3>
<p>Плагины Pixel Perfect, PerfectPixel, Page Ruler позволяют наложить макет на готовую страницу, увидеть расхождения до пикселя.</p>
<h3 id="heading-3-34">Производительность и оптимизация</h3>
<p>Проверить скорость загрузки можно с помощью Lighthouse и Web Vitals. Они оценивают время отображения контента, отзывчивость интерфейса и стабильность макета. Качественная вёрстка — это баланс между визуальной точностью, оптимизацией и удобством поддержки.</p>
<h2 id="heading-2-35">Современные тенденции</h2>
<p>Мир фронтенда развивается стремительно, вместе с ним меняются подходы к вёрстке. Сегодня важно не просто «сделать страницу», а обеспечить удобство, скорость, масштабируемость.</p>
<h3 id="heading-3-36">Mobile-first и responsive дизайн</h3>
<p>Современная разработка строится по принципу mobile-first — сначала проектируется версия для смартфона, а затем расширяется до десктопа. Это логично: большинство пользователей приходят с мобильных устройств, именно там важно обеспечить удобный интерфейс и минимальные задержки загрузки.</p>
<h3 id="heading-3-37">CSS Grid и Flexbox как стандарт</h3>
<p>Раньше создание сеток требовало сложных вложений и хака с float’ами. Теперь всё проще: Grid и Flexbox стали золотым стандартом. Grid — для сложных макетов, Flexbox — для гибкого выравнивания элементов в строках и столбцах. Вместе они обеспечивают точный контроль над структурой.</p>
<h3 id="heading-3-38">CSS Variables и кастомные свойства</h3>
<p>Кастомные свойства (--color-primary, --font-size-base) делают код динамичным. Изменив значение переменной, можно мгновенно поменять цветовую схему или тему сайта. Это особенно актуально для тёмного режима и дизайн-систем.</p>
<h3 id="heading-3-39">UI-фреймворки и библиотеки</h3>
<p>Быстрая разработка невозможна без готовых решений. Самые популярные инструменты:</p>
<ul>
<li><strong>Bootstrap</strong> — проверенная временем библиотека компонентов;</li>
<li><strong>Tailwind CSS</strong> — утилитарный фреймворк с фокусом на кастомизацию;</li>
<li><strong>Material UI</strong> — визуальный язык от Google, интегрируемый с React.</li>
</ul>
<p>UI-фреймворки экономят время, но важно не терять индивидуальность дизайна.</p>
<h3 id="heading-3-40">Интерактивная вёрстка</h3>
<p>Граница между верстальщиком и фронтендером всё больше стирается. Многие проекты требуют базовых знаний React или Vue — библиотек, которые позволяют создавать динамичные интерфейсы без перезагрузки страниц. Современный верстальщик должен не только знать CSS, но и понимать, как компоненты работают в связке с JavaScript.</p>
<h2 id="heading-2-41">Ошибки и советы</h2>
<h3 id="heading-3-42">Типичные промахи</h3>
<ol>
<li><strong>Неверная вложенность элементов.</strong> Ошибка в структуре HTML ломает вёрстку на уровне браузера.</li>
<li><strong>Избыточные inline-стили.</strong> Они усложняют поддержку, противоречат принципам разделения кода.</li>
<li><strong>Отсутствие alt у изображений.</strong> Это мешает SEO и доступности.</li>
<li><strong>Жёсткие размеры без адаптации.</strong> Страница «сыплется» на мобильных устройствах.</li>
</ol>
<h3 id="heading-3-43">Советы по оптимизации</h3>
<ul>
<li>Используйте относительные единицы (em, %, rem) — они позволяют масштабировать интерфейс.</li>
<li>Минимизируйте и объединяйте CSS-файлы для ускорения загрузки.</li>
<li>Следите за иерархией заголовков (h1–h6) — это важно для SEO и логики восприятия.</li>
<li>Структурируйте проект: отдельные папки для стилей, изображений, скриптов.</li>
</ul>
<h3 id="heading-3-44">Оптимизация под производительность</h3>
<p>Вёрстка напрямую влияет на скорость сайта. Чем меньше CSS и запросов к серверу — тем быстрее откроется страница. Инструменты вроде Lighthouse помогают оценить и улучшить показатели.</p>
<p><img style="--image-object-fit:contain;width:auto" class="m_9e117634 mantine-Image-root" src="https://cdn6.hexlet.io/vkejUFHO3aKZ.png" alt="VkejUFHO3aKZ image" loading="lazy"/></p>
<h2 id="heading-2-45">Профессия верстальщика</h2>
<p>Вёрстка — одна из самых доступных точек входа в IT, особенно для тех, кто только начинает путь в разработке.</p>
<h3 id="heading-3-46">Кто такой верстальщик</h3>
<p>Это специалист, который создаёт HTML/CSS-код на основе дизайнерских макетов. Он отвечает за визуальную часть сайта, совместимость с браузерами, адаптивность.</p>
<h3 id="heading-3-47">Необходимые навыки</h3>
<ul>
<li>знание <strong>HTML5</strong> и <strong>CSS3</strong>;</li>
<li>основы <strong>JavaScript</strong>;</li>
<li>принципы адаптивного и кроссбраузерного дизайна;</li>
<li>умение работать с инструментами (Git, Figma, DevTools).</li>
</ul>
<h3 id="heading-3-48">Карьера и перспективы</h3>
<p>Можно расти в нескольких направлениях:</p>
<ul>
<li><strong>Frontend-разработка</strong> — логичное продолжение пути;</li>
<li><strong>UI-инженерия</strong> — специализация на интерфейсах и анимациях;</li>
<li><strong>Web performance</strong> — оптимизация скорости и качества сайтов.</li>
</ul>
<p>Спрос на внимательных специалистов с сильным чувством структуры стабильно высок: компании нуждаются в разработчиках, которые умеют превращать дизайн в чистый, гибкий код.</p>
<h3 id="heading-3-49">Обучение</h3>
<p>Онлайн-школы (Hexlet, Skillfactory, Coursera) предлагают курсы, где студенты шаг за шагом осваивают HTML, CSS, JavaScript на практике. Главное — не просто слушать лекции, а верстать реальные проекты, анализировать ошибки, искать способы улучшить код.</p>
<h2 id="heading-2-50">Заключение</h2>
<p>Вёрстка — это мост между идеей и её воплощением. Она делает дизайн доступным пользователю, а интерфейс — удобным и красивым. Современный верстальщик сочетает точность инженера и вкус дизайнера. В мире разработки нет мелочей: каждый пиксель важен. Поэтому, если вы только начинаете путь в IT — начните с вёрстки. Она научит вас логике, внимательности, дисциплине кода — качествам хорошего программиста.</p></div><div class="m_3eebeb36 mantine-Divider-root" data-orientation="horizontal" role="separator"></div><div style="--group-gap:var(--mantine-spacing-md);--group-align:center;--group-justify:flex-start;--group-wrap:wrap;font-size:var(--mantine-font-size-sm)" class="m_4081bf90 mantine-Group-root"><div style="--group-gap:var(--mantine-spacing-xs);--group-align:center;--group-justify:flex-start;--group-wrap:wrap;margin-inline-start:auto" class="m_4081bf90 mantine-Group-root"><svg xmlns="http://www.w3.org/2000/svg" width="16" height="16" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="1.2" stroke-linecap="round" stroke-linejoin="round" class="tabler-icon tabler-icon-calendar "><path d="M4 7a2 2 0 0 1 2 -2h12a2 2 0 0 1 2 2v12a2 2 0 0 1 -2 2h-12a2 2 0 0 1 -2 -2v-12"></path><path d="M16 3v4"></path><path d="M8 3v4"></path><path d="M4 11h16"></path><path d="M11 15h1"></path><path d="M12 15v3"></path></svg><p class="mantine-focus-auto m_b6d8b162 mantine-Text-root" data-inherit="true">3 месяца назад</p></div><div style="--group-gap:var(--mantine-spacing-xs);--group-align:center;--group-justify:flex-start;--group-wrap:wrap" class="m_4081bf90 mantine-Group-root"><svg xmlns="http://www.w3.org/2000/svg" width="16" height="16" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="1.2" stroke-linecap="round" stroke-linejoin="round" class="tabler-icon tabler-icon-user "><path d="M8 7a4 4 0 1 0 8 0a4 4 0 0 0 -8 0"></path><path d="M6 21v-2a4 4 0 0 1 4 -4h4a4 4 0 0 1 4 4v2"></path></svg><p class="mantine-focus-auto m_b6d8b162 mantine-Text-root" data-inherit="true">Nikolai Gagarinov</p></div></div></div></div></div><div style="margin-bottom:var(--mantine-spacing-xl);padding:var(--mantine-spacing-lg)" class="m_e615b15f mantine-Card-root m_1b7284a3 mantine-Paper-root" data-with-border="true" id="answer-3093"><div style="--group-gap:calc(1.125rem * var(--mantine-scale));--group-align:stretch;--group-justify:flex-start;--group-wrap:nowrap" class="m_4081bf90 mantine-Group-root"><div style="--stack-gap:var(--mantine-spacing-md);--stack-align:stretch;--stack-justify:flex-start;font-size:var(--mantine-font-size-h1);font-weight:lighter;text-align:center" class="m_6d731127 mantine-Stack-root">0<a style="color:inherit" class="mantine-focus-auto m_849cf0da m_b6d8b162 mantine-Text-root mantine-Anchor-root" data-underline="hover" href="/qna/glossary/questions/chto-takoe-verstka/answers/3093/vote"><div style="--ti-bg:transparent;--ti-color:var(--mantine-color-indigo-light-color);--ti-bd:calc(0.0625rem * var(--mantine-scale)) solid transparent;color:inherit" class="m_7341320d mantine-ThemeIcon-root" data-variant="transparent"><svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" class="tabler-icon tabler-icon-thumb-up "><path d="M7 11v8a1 1 0 0 1 -1 1h-2a1 1 0 0 1 -1 -1v-7a1 1 0 0 1 1 -1h3a4 4 0 0 0 4 -4v-1a2 2 0 0 1 4 0v5h3a2 2 0 0 1 2 2l-1 5a2 3 0 0 1 -2 2h-7a3 3 0 0 1 -3 -3"></path></svg></div></a></div><div style="--stack-gap:var(--mantine-spacing-md);--stack-align:stretch;--stack-justify:flex-start;width:100%;min-width:0rem" class="m_6d731127 mantine-Stack-root"><div style="margin-bottom:auto" class="m_d08caa0 mantine-Typography-root"><p>Верстка - это процесс создания макета страницы или документа. В веб-разработке верстка означает создание HTML-кода и CSS-стилей, которые определяют структуру и внешний вид веб-страницы. После верстки страница может быть отображена в браузере и проверена на наличие ошибок.</p></div><div class="m_3eebeb36 mantine-Divider-root" data-orientation="horizontal" role="separator"></div><div style="--group-gap:var(--mantine-spacing-md);--group-align:center;--group-justify:flex-start;--group-wrap:wrap;font-size:var(--mantine-font-size-sm)" class="m_4081bf90 mantine-Group-root"><div style="--group-gap:var(--mantine-spacing-xs);--group-align:center;--group-justify:flex-start;--group-wrap:wrap;margin-inline-start:auto" class="m_4081bf90 mantine-Group-root"><svg xmlns="http://www.w3.org/2000/svg" width="16" height="16" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="1.2" stroke-linecap="round" stroke-linejoin="round" class="tabler-icon tabler-icon-calendar "><path d="M4 7a2 2 0 0 1 2 -2h12a2 2 0 0 1 2 2v12a2 2 0 0 1 -2 2h-12a2 2 0 0 1 -2 -2v-12"></path><path d="M16 3v4"></path><path d="M8 3v4"></path><path d="M4 11h16"></path><path d="M11 15h1"></path><path d="M12 15v3"></path></svg><p class="mantine-focus-auto m_b6d8b162 mantine-Text-root" data-inherit="true">2 года назад</p></div><div style="--group-gap:var(--mantine-spacing-xs);--group-align:center;--group-justify:flex-start;--group-wrap:wrap" class="m_4081bf90 mantine-Group-root"><svg xmlns="http://www.w3.org/2000/svg" width="16" height="16" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="1.2" stroke-linecap="round" stroke-linejoin="round" class="tabler-icon tabler-icon-user "><path d="M8 7a4 4 0 1 0 8 0a4 4 0 0 0 -8 0"></path><path d="M6 21v-2a4 4 0 0 1 4 -4h4a4 4 0 0 1 4 4v2"></path></svg><p class="mantine-focus-auto m_b6d8b162 mantine-Text-root" data-inherit="true">Елена Редькина</p></div></div></div></div></div><style data-mantine-styles="inline">.__m__-_R_4bbdiub_{--carousel-slide-gap:var(--mantine-spacing-xs);--carousel-slide-size:70%;}@media(min-width: 36em){.__m__-_R_4bbdiub_{--carousel-slide-gap:var(--mantine-spacing-xl);--carousel-slide-size:50%;}}</style><div style="--carousel-control-size:calc(2.5rem * var(--mantine-scale));--carousel-controls-offset:var(--mantine-spacing-sm);margin-top:var(--mantine-spacing-xl);margin-bottom:var(--mantine-spacing-lg);padding-block:var(--mantine-spacing-sm);background:var(--app-color-surface)" class="m_17884d0f mantine-Carousel-root responsiveClassName" data-orientation="horizontal" data-include-gap-in-size="true"><div class="m_39bc3463 mantine-Carousel-controls" data-orientation="horizontal"><button class="mantine-focus-auto m_64f58e10 mantine-Carousel-control m_87cf2631 mantine-UnstyledButton-root" type="button" data-inactive="true" data-type="previous" tabindex="-1"><svg viewBox="0 0 15 15" fill="none" xmlns="http://www.w3.org/2000/svg" style="transform:rotate(90deg);width:calc(1rem * var(--mantine-scale));height:calc(1rem * var(--mantine-scale));display:block"><path d="M3.13523 6.15803C3.3241 5.95657 3.64052 5.94637 3.84197 6.13523L7.5 9.56464L11.158 6.13523C11.3595 5.94637 11.6759 5.95657 11.8648 6.15803C12.0536 6.35949 12.0434 6.67591 11.842 6.86477L7.84197 10.6148C7.64964 10.7951 7.35036 10.7951 7.15803 10.6148L3.15803 6.86477C2.95657 6.67591 2.94637 6.35949 3.13523 6.15803Z" fill="currentColor" fill-rule="evenodd" clip-rule="evenodd"></path></svg></button><button class="mantine-focus-auto m_64f58e10 mantine-Carousel-control m_87cf2631 mantine-UnstyledButton-root" type="button" data-inactive="true" data-type="next" tabindex="-1"><svg viewBox="0 0 15 15" fill="none" xmlns="http://www.w3.org/2000/svg" style="transform:rotate(-90deg);width:calc(1rem * var(--mantine-scale));height:calc(1rem * var(--mantine-scale));display:block"><path d="M3.13523 6.15803C3.3241 5.95657 3.64052 5.94637 3.84197 6.13523L7.5 9.56464L11.158 6.13523C11.3595 5.94637 11.6759 5.95657 11.8648 6.15803C12.0536 6.35949 12.0434 6.67591 11.842 6.86477L7.84197 10.6148C7.64964 10.7951 7.35036 10.7951 7.15803 10.6148L3.15803 6.86477C2.95657 6.67591 2.94637 6.35949 3.13523 6.15803Z" fill="currentColor" fill-rule="evenodd" clip-rule="evenodd"></path></svg></button></div><div class="m_a2dae653 mantine-Carousel-viewport" data-type="media"><div class="m_fcd81474 mantine-Carousel-container __m__-_R_4bbdiub_" data-orientation="horizontal"><div class="m_d98df724 mantine-Carousel-slide" data-orientation="horizontal"><div tabindex="0" style="cursor:pointer;height:100%"><a style="text-decoration:none" class="mantine-focus-auto m_849cf0da m_b6d8b162 mantine-Text-root mantine-Anchor-root" data-underline="hover" href="/programs/professional-layout?promo_name=programs_list&promo_position=qna_question&promo_creative=catalog_card&promo_type=card" target="_blank"><div style="height:100%" class="m_e615b15f mantine-Card-root m_1b7284a3 mantine-Paper-root" data-with-border="true"><div style="--group-gap:calc(0.25rem * var(--mantine-scale));--group-align:center;--group-justify:flex-start;--group-wrap:nowrap" class="m_4081bf90 mantine-Group-root"><span style="font-size:var(--mantine-font-size-sm)" class="mantine-focus-auto m_b6d8b162 mantine-Text-root">5 месяцев</span><span class="mantine-focus-auto m_b6d8b162 mantine-Text-root">·</span><span style="font-size:var(--mantine-font-size-sm)" class="mantine-focus-auto m_b6d8b162 mantine-Text-root">С нуля</span></div><p style="margin-bottom:var(--mantine-spacing-sm);font-size:var(--mantine-font-size-h5);font-weight:bold" class="mantine-focus-auto m_b6d8b162 mantine-Text-root">Профессиональная верстка</p><p class="mantine-focus-auto m_b6d8b162 mantine-Text-root">Адаптивная вёрстка для отображения на любых устройствах </p><div style="margin-top:auto" class=""><div class="m_4451eb3a mantine-Center-root"><img style="opacity:0.8;width:70%" class="m_9e117634 mantine-Image-root mantine-visible-from-xs" src="https://hexlet.io/rails/active_storage/representations/proxy/eyJfcmFpbHMiOnsiZGF0YSI6NDAzNCwicHVyIjoiYmxvYl9pZCJ9fQ==--ba516ea9573bdfcd1d21e2aa0fff8818561828f2/eyJfcmFpbHMiOnsiZGF0YSI6eyJmb3JtYXQiOiJ3ZWJwIiwicmVzaXplX3RvX2xpbWl0IjpbNDAwLDQwMF0sInNhdmVyIjp7InF1YWxpdHkiOjg1fX0sInB1ciI6InZhcmlhdGlvbiJ9fQ==--5b6f46dacd1af664f27558553a58076185091823/Typing-bro.png" alt="Профессиональная верстка" loading="eager"/></div><div style="--group-gap:var(--mantine-spacing-md);--group-align:end;--group-justify:space-between;--group-wrap:wrap;margin-top:var(--mantine-spacing-xs)" class="m_4081bf90 mantine-Group-root"><p style="font-size:var(--mantine-font-size-xl)" class="mantine-focus-auto m_b6d8b162 mantine-Text-root">от 3 900 ₽</p><p style="font-size:var(--mantine-font-size-sm)" class="mantine-focus-auto m_b6d8b162 mantine-Text-root">Посмотреть →</p></div></div></div></a></div></div><div class="m_d98df724 mantine-Carousel-slide" data-orientation="horizontal"><div tabindex="0" style="cursor:pointer;height:100%"><a style="text-decoration:none" class="mantine-focus-auto m_849cf0da m_b6d8b162 mantine-Text-root mantine-Anchor-root" data-underline="hover" href="/programs/frontend?promo_name=programs_list&promo_position=qna_question&promo_creative=catalog_card&promo_type=card" target="_blank"><div style="height:100%" class="m_e615b15f mantine-Card-root m_1b7284a3 mantine-Paper-root" data-with-border="true"><div style="--group-gap:calc(0.25rem * var(--mantine-scale));--group-align:center;--group-justify:flex-start;--group-wrap:nowrap" class="m_4081bf90 mantine-Group-root"><span style="font-size:var(--mantine-font-size-sm)" class="mantine-focus-auto m_b6d8b162 mantine-Text-root">10 месяцев</span><span class="mantine-focus-auto m_b6d8b162 mantine-Text-root">·</span><span style="font-size:var(--mantine-font-size-sm)" class="mantine-focus-auto m_b6d8b162 mantine-Text-root">С нуля</span></div><p style="margin-bottom:var(--mantine-spacing-sm);font-size:var(--mantine-font-size-h5);font-weight:bold" class="mantine-focus-auto m_b6d8b162 mantine-Text-root">Фронтенд-разработчик</p><p class="mantine-focus-auto m_b6d8b162 mantine-Text-root">Изучите HTML, CSS, JavaScript и React</p><div style="margin-top:auto" class=""><div class="m_4451eb3a mantine-Center-root"><img style="opacity:0.8;width:70%" class="m_9e117634 mantine-Image-root mantine-visible-from-xs" src="https://hexlet.io/rails/active_storage/representations/proxy/eyJfcmFpbHMiOnsiZGF0YSI6MzcyNywicHVyIjoiYmxvYl9pZCJ9fQ==--2d5cbbf5c3b4a73ae4b2c50632305d78f5872e4d/eyJfcmFpbHMiOnsiZGF0YSI6eyJmb3JtYXQiOiJ3ZWJwIiwicmVzaXplX3RvX2xpbWl0IjpbNDAwLDQwMF0sInNhdmVyIjp7InF1YWxpdHkiOjg1fX0sInB1ciI6InZhcmlhdGlvbiJ9fQ==--5b6f46dacd1af664f27558553a58076185091823/Programmer-rafiki.png" alt="Фронтенд-разработчик" loading="eager"/></div><div style="--group-gap:var(--mantine-spacing-md);--group-align:end;--group-justify:space-between;--group-wrap:wrap;margin-top:var(--mantine-spacing-xs)" class="m_4081bf90 mantine-Group-root"><p style="font-size:var(--mantine-font-size-xl)" class="mantine-focus-auto m_b6d8b162 mantine-Text-root">от 6 792 ₽</p><p style="font-size:var(--mantine-font-size-sm)" class="mantine-focus-auto m_b6d8b162 mantine-Text-root">Посмотреть →</p></div></div></div></a></div></div><div class="m_d98df724 mantine-Carousel-slide" data-orientation="horizontal"><div tabindex="0" style="cursor:pointer;height:100%"><a style="text-decoration:none" class="mantine-focus-auto m_849cf0da m_b6d8b162 mantine-Text-root mantine-Anchor-root" data-underline="hover" href="/programs/layout-designer-positioning?promo_name=programs_list&promo_position=qna_question&promo_creative=catalog_card&promo_type=card" target="_blank"><div style="height:100%" class="m_e615b15f mantine-Card-root m_1b7284a3 mantine-Paper-root" data-with-border="true"><div style="--group-gap:calc(0.25rem * var(--mantine-scale));--group-align:center;--group-justify:flex-start;--group-wrap:nowrap" class="m_4081bf90 mantine-Group-root"><span style="font-size:var(--mantine-font-size-sm)" class="mantine-focus-auto m_b6d8b162 mantine-Text-root">1 месяц</span><span class="mantine-focus-auto m_b6d8b162 mantine-Text-root">·</span><span style="font-size:var(--mantine-font-size-sm)" class="mantine-focus-auto m_b6d8b162 mantine-Text-root">Для продвинутых</span></div><p style="margin-bottom:var(--mantine-spacing-sm);font-size:var(--mantine-font-size-h5);font-weight:bold" class="mantine-focus-auto m_b6d8b162 mantine-Text-root">Позиционирование в CSS</p><p class="mantine-focus-auto m_b6d8b162 mantine-Text-root">Получите навык работы с CSS и адаптивными интерфейсами</p><div style="margin-top:auto" class=""><div class="m_4451eb3a mantine-Center-root"><img style="opacity:0.8;width:70%" class="m_9e117634 mantine-Image-root mantine-visible-from-xs" src="https://hexlet.io/rails/active_storage/representations/proxy/eyJfcmFpbHMiOnsiZGF0YSI6NDAwNCwicHVyIjoiYmxvYl9pZCJ9fQ==--43a2eb3595eeebb3357d478cbcb752d0026363de/eyJfcmFpbHMiOnsiZGF0YSI6eyJmb3JtYXQiOiJ3ZWJwIiwicmVzaXplX3RvX2xpbWl0IjpbNDAwLDQwMF0sInNhdmVyIjp7InF1YWxpdHkiOjg1fX0sInB1ciI6InZhcmlhdGlvbiJ9fQ==--5b6f46dacd1af664f27558553a58076185091823/Website%20Creator-cuate.png" alt="Позиционирование в CSS" loading="eager"/></div><div style="--group-gap:var(--mantine-spacing-md);--group-align:end;--group-justify:space-between;--group-wrap:wrap;margin-top:var(--mantine-spacing-xs)" class="m_4081bf90 mantine-Group-root"><p style="font-size:var(--mantine-font-size-xl)" class="mantine-focus-auto m_b6d8b162 mantine-Text-root">от 3 900 ₽</p><p style="font-size:var(--mantine-font-size-sm)" class="mantine-focus-auto m_b6d8b162 mantine-Text-root">Посмотреть →</p></div></div></div></a></div></div><div class="m_d98df724 mantine-Carousel-slide" data-orientation="horizontal"><div tabindex="0" style="cursor:pointer;height:100%"><a style="text-decoration:none" class="mantine-focus-auto m_849cf0da m_b6d8b162 mantine-Text-root mantine-Anchor-root" data-underline="hover" href="/programs/layout-designer-bootstrap?promo_name=programs_list&promo_position=qna_question&promo_creative=catalog_card&promo_type=card" target="_blank"><div style="height:100%" class="m_e615b15f mantine-Card-root m_1b7284a3 mantine-Paper-root" data-with-border="true"><div style="--group-gap:calc(0.25rem * var(--mantine-scale));--group-align:center;--group-justify:flex-start;--group-wrap:nowrap" class="m_4081bf90 mantine-Group-root"><span style="font-size:var(--mantine-font-size-sm)" class="mantine-focus-auto m_b6d8b162 mantine-Text-root">2 месяца</span><span class="mantine-focus-auto m_b6d8b162 mantine-Text-root">·</span><span style="font-size:var(--mantine-font-size-sm)" class="mantine-focus-auto m_b6d8b162 mantine-Text-root">Для продвинутых</span></div><p style="margin-bottom:var(--mantine-spacing-sm);font-size:var(--mantine-font-size-h5);font-weight:bold" class="mantine-focus-auto m_b6d8b162 mantine-Text-root">Bootstrap</p><p class="mantine-focus-auto m_b6d8b162 mantine-Text-root">Изучите навык для работы с Bootstrap 5, SASS и Gulp для быстрой вёрстки</p><div style="margin-top:auto" class=""><div class="m_4451eb3a mantine-Center-root"><img style="opacity:0.8;width:70%" class="m_9e117634 mantine-Image-root mantine-visible-from-xs" src="https://hexlet.io/rails/active_storage/representations/proxy/eyJfcmFpbHMiOnsiZGF0YSI6NDA0MCwicHVyIjoiYmxvYl9pZCJ9fQ==--137ae65fe79f41b3d5270b8a3b65b38b1621c65b/eyJfcmFpbHMiOnsiZGF0YSI6eyJmb3JtYXQiOiJ3ZWJwIiwicmVzaXplX3RvX2xpbWl0IjpbNDAwLDQwMF0sInNhdmVyIjp7InF1YWxpdHkiOjg1fX0sInB1ciI6InZhcmlhdGlvbiJ9fQ==--5b6f46dacd1af664f27558553a58076185091823/Code%20typing-bro.png" alt="Bootstrap" loading="eager"/></div><div style="--group-gap:var(--mantine-spacing-md);--group-align:end;--group-justify:space-between;--group-wrap:wrap;margin-top:var(--mantine-spacing-xs)" class="m_4081bf90 mantine-Group-root"><p style="font-size:var(--mantine-font-size-xl)" class="mantine-focus-auto m_b6d8b162 mantine-Text-root">от 3 900 ₽</p><p style="font-size:var(--mantine-font-size-sm)" class="mantine-focus-auto m_b6d8b162 mantine-Text-root">Посмотреть →</p></div></div></div></a></div></div><div class="m_d98df724 mantine-Carousel-slide" data-orientation="horizontal"><div tabindex="0" style="cursor:pointer;height:100%"><a style="text-decoration:none" class="mantine-focus-auto m_849cf0da m_b6d8b162 mantine-Text-root mantine-Anchor-root" data-underline="hover" href="/programs/sass?promo_name=programs_list&promo_position=qna_question&promo_creative=catalog_card&promo_type=card" target="_blank"><div style="height:100%" class="m_e615b15f mantine-Card-root m_1b7284a3 mantine-Paper-root" data-with-border="true"><div style="--group-gap:calc(0.25rem * var(--mantine-scale));--group-align:center;--group-justify:flex-start;--group-wrap:nowrap" class="m_4081bf90 mantine-Group-root"><span style="font-size:var(--mantine-font-size-sm)" class="mantine-focus-auto m_b6d8b162 mantine-Text-root">1 месяц</span><span class="mantine-focus-auto m_b6d8b162 mantine-Text-root">·</span><span style="font-size:var(--mantine-font-size-sm)" class="mantine-focus-auto m_b6d8b162 mantine-Text-root">Для продвинутых</span></div><p style="margin-bottom:var(--mantine-spacing-sm);font-size:var(--mantine-font-size-h5);font-weight:bold" class="mantine-focus-auto m_b6d8b162 mantine-Text-root">SASS</p><p class="mantine-focus-auto m_b6d8b162 mantine-Text-root">Освоите препроцессор SASS и стилизацию веб-приложений</p><div style="margin-top:auto" class=""><div class="m_4451eb3a mantine-Center-root"><img style="opacity:0.8;width:70%" class="m_9e117634 mantine-Image-root mantine-visible-from-xs" src="https://hexlet.io/rails/active_storage/representations/proxy/eyJfcmFpbHMiOnsiZGF0YSI6NDAyMiwicHVyIjoiYmxvYl9pZCJ9fQ==--8e763c5a65cfc8d5e67cb29ae3d1881ad23c714e/eyJfcmFpbHMiOnsiZGF0YSI6eyJmb3JtYXQiOiJ3ZWJwIiwicmVzaXplX3RvX2xpbWl0IjpbNDAwLDQwMF0sInNhdmVyIjp7InF1YWxpdHkiOjg1fX0sInB1ciI6InZhcmlhdGlvbiJ9fQ==--5b6f46dacd1af664f27558553a58076185091823/Hand%20coding-bro.png" alt="SASS" loading="eager"/></div><div style="--group-gap:var(--mantine-spacing-md);--group-align:end;--group-justify:space-between;--group-wrap:wrap;margin-top:var(--mantine-spacing-xs)" class="m_4081bf90 mantine-Group-root"><p style="font-size:var(--mantine-font-size-xl)" class="mantine-focus-auto m_b6d8b162 mantine-Text-root">от 3 900 ₽</p><p style="font-size:var(--mantine-font-size-sm)" class="mantine-focus-auto m_b6d8b162 mantine-Text-root">Посмотреть →</p></div></div></div></a></div></div><div class="m_d98df724 mantine-Carousel-slide" data-orientation="horizontal"><div tabindex="0" style="cursor:pointer;height:100%"><a style="text-decoration:none" class="mantine-focus-auto m_849cf0da m_b6d8b162 mantine-Text-root mantine-Anchor-root" data-underline="hover" href="/courses?promo_name=programs_list&promo_position=qna_question&promo_creative=catalog_card&promo_type=card"><div style="height:100%" class="m_e615b15f mantine-Card-root m_1b7284a3 mantine-Paper-root" data-with-border="true"><h2 style="--title-fw:var(--mantine-h2-font-weight);--title-lh:var(--mantine-h2-line-height);--title-fz:var(--mantine-h2-font-size);margin-bottom:var(--mantine-spacing-md);font-size:var(--mantine-font-size-h3)" class="m_8a5d1357 mantine-Title-root" data-order="2" data-responsive="true">Каталог</h2><p style="margin-bottom:auto" class="mantine-focus-auto m_b6d8b162 mantine-Text-root">Полный список доступных курсов по разным направлениям</p><div style="margin-top:auto" class=""><div class="m_4451eb3a mantine-Center-root"><img style="opacity:0.8;width:70%" class="m_9e117634 mantine-Image-root mantine-visible-from-xs" src="/vite/assets/development-BVihs_d5.png" alt="Orientation"/></div></div></div></a></div></div></div></div></div></div><style data-mantine-styles="inline">.__m__-_R_5diub_{--col-flex-grow:auto;--col-flex-basis:100%;--col-max-width:100%;}@media(min-width: 48em){.__m__-_R_5diub_{--col-flex-grow:auto;--col-flex-basis:16.666666666666668%;--col-max-width:16.666666666666668%;}}@media(min-width: 62em){.__m__-_R_5diub_{--col-flex-grow:auto;--col-flex-basis:33.333333333333336%;--col-max-width:33.333333333333336%;}}</style><div class="m_96bdd299 mantine-Grid-col __m__-_R_5diub_ mantine-visible-from-md"><div style="margin-bottom:var(--mantine-spacing-xl);padding:var(--mantine-spacing-xl);background:var(--mantine-color-blue-0);width:100%" class="m_e615b15f mantine-Card-root m_1b7284a3 mantine-Paper-root"><p style="margin-bottom:var(--mantine-spacing-sm);font-size:var(--mantine-font-size-h4)" class="mantine-focus-auto m_b6d8b162 mantine-Text-root">Похожие вопросы</p><ul class="m_abbac491 mantine-List-root"><li style="margin-bottom:var(--mantine-spacing-xs)" class="m_abb6bec2 mantine-List-item" data-with-icon="true"><div class="m_75cd9f71 mantine-List-itemWrapper"><span class="m_60f83e5b mantine-List-itemIcon"><div class="m_4451eb3a mantine-Center-root"><div style="--ti-size:var(--ti-size-xs);--ti-bg:transparent;--ti-color:var(--mantine-color-indigo-light-color);--ti-bd:calc(0.0625rem * var(--mantine-scale)) solid transparent;color:inherit" class="m_7341320d mantine-ThemeIcon-root" data-variant="transparent" data-size="xs"><svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" class="tabler-icon tabler-icon-chevron-compact-right "><path d="M11 4l3 8l-3 8"></path></svg></div></div></span><span class="mantine-List-itemLabel"><a class="mantine-focus-auto m_849cf0da m_b6d8b162 mantine-Text-root mantine-Anchor-root" data-underline="hover" href="/qna/glossary/questions/chto-takoe-pandas">Pandas</a></span></div></li><li style="margin-bottom:var(--mantine-spacing-xs)" class="m_abb6bec2 mantine-List-item" data-with-icon="true"><div class="m_75cd9f71 mantine-List-itemWrapper"><span class="m_60f83e5b mantine-List-itemIcon"><div class="m_4451eb3a mantine-Center-root"><div style="--ti-size:var(--ti-size-xs);--ti-bg:transparent;--ti-color:var(--mantine-color-indigo-light-color);--ti-bd:calc(0.0625rem * var(--mantine-scale)) solid transparent;color:inherit" class="m_7341320d mantine-ThemeIcon-root" data-variant="transparent" data-size="xs"><svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" class="tabler-icon tabler-icon-chevron-compact-right "><path d="M11 4l3 8l-3 8"></path></svg></div></div></span><span class="mantine-List-itemLabel"><a class="mantine-focus-auto m_849cf0da m_b6d8b162 mantine-Text-root mantine-Anchor-root" data-underline="hover" href="/qna/glossary/questions/chto-takoe-1c-buhgalteriya">1C:Бухгалтерия</a></span></div></li><li style="margin-bottom:var(--mantine-spacing-xs)" class="m_abb6bec2 mantine-List-item" data-with-icon="true"><div class="m_75cd9f71 mantine-List-itemWrapper"><span class="m_60f83e5b mantine-List-itemIcon"><div class="m_4451eb3a mantine-Center-root"><div style="--ti-size:var(--ti-size-xs);--ti-bg:transparent;--ti-color:var(--mantine-color-indigo-light-color);--ti-bd:calc(0.0625rem * var(--mantine-scale)) solid transparent;color:inherit" class="m_7341320d mantine-ThemeIcon-root" data-variant="transparent" data-size="xs"><svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" class="tabler-icon tabler-icon-chevron-compact-right "><path d="M11 4l3 8l-3 8"></path></svg></div></div></span><span class="mantine-List-itemLabel"><a class="mantine-focus-auto m_849cf0da m_b6d8b162 mantine-Text-root mantine-Anchor-root" data-underline="hover" href="/qna/glossary/questions/chto-takoe-1c-predpriyatie">1C:Предприятие</a></span></div></li><li style="margin-bottom:var(--mantine-spacing-xs)" class="m_abb6bec2 mantine-List-item" data-with-icon="true"><div class="m_75cd9f71 mantine-List-itemWrapper"><span class="m_60f83e5b mantine-List-itemIcon"><div class="m_4451eb3a mantine-Center-root"><div style="--ti-size:var(--ti-size-xs);--ti-bg:transparent;--ti-color:var(--mantine-color-indigo-light-color);--ti-bd:calc(0.0625rem * var(--mantine-scale)) solid transparent;color:inherit" class="m_7341320d mantine-ThemeIcon-root" data-variant="transparent" data-size="xs"><svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" class="tabler-icon tabler-icon-chevron-compact-right "><path d="M11 4l3 8l-3 8"></path></svg></div></div></span><span class="mantine-List-itemLabel"><a class="mantine-focus-auto m_849cf0da m_b6d8b162 mantine-Text-root mantine-Anchor-root" data-underline="hover" href="/qna/glossary/questions/chto-takoe-a-b-testirovanie">A/B-тестирование</a></span></div></li><li style="margin-bottom:var(--mantine-spacing-xs)" class="m_abb6bec2 mantine-List-item" data-with-icon="true"><div class="m_75cd9f71 mantine-List-itemWrapper"><span class="m_60f83e5b mantine-List-itemIcon"><div class="m_4451eb3a mantine-Center-root"><div style="--ti-size:var(--ti-size-xs);--ti-bg:transparent;--ti-color:var(--mantine-color-indigo-light-color);--ti-bd:calc(0.0625rem * var(--mantine-scale)) solid transparent;color:inherit" class="m_7341320d mantine-ThemeIcon-root" data-variant="transparent" data-size="xs"><svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" class="tabler-icon tabler-icon-chevron-compact-right "><path d="M11 4l3 8l-3 8"></path></svg></div></div></span><span class="mantine-List-itemLabel"><a class="mantine-focus-auto m_849cf0da m_b6d8b162 mantine-Text-root mantine-Anchor-root" data-underline="hover" href="/qna/glossary/questions/chto-takoe-agile">Agile</a></span></div></li></ul></div><div style="justify-content:end;margin-top:0rem;position:sticky;top:calc(5rem * var(--mantine-scale))" class="m_8bffd616 mantine-Flex-root __m__-_R_1bddiub_"><div tabindex="0" style="cursor:pointer"><a style="text-decoration:none" class="mantine-focus-auto m_849cf0da m_b6d8b162 mantine-Text-root mantine-Anchor-root" data-underline="hover" href="/courses_web_development?promo_name=program_category&promo_position=qna_question&promo_creative=card&promo_type=card"><div style="background-color:var(--mantine-color-default);border:calc(0.0625rem * var(--mantine-scale)) solid var(--mantine-color-default-border);padding-inline:var(--mantine-spacing-xl);padding-top:var(--mantine-spacing-xl);padding-bottom:var(--mantine-spacing-xs);width:100%" class="m_e615b15f mantine-Card-root m_1b7284a3 mantine-Paper-root"><div class="m_4451eb3a mantine-Center-root" data-inline="true"><p style="font-size:var(--mantine-font-size-h4)" class="mantine-focus-auto m_b6d8b162 mantine-Text-root">Курсы по веб-разработке</p></div><img class="m_9e117634 mantine-Image-root" src="/vite/assets/development-BVihs_d5.png"/><p style="margin-bottom:var(--mantine-spacing-xs);text-align:right" class="mantine-focus-auto m_b6d8b162 mantine-Text-root">Посмотреть →</p></div></a></div></div></div></div></div></div></div>
</main>
<footer class="bg-dark fw-light text-light px-3 py-5">
<div class="row small">
<div class="col-12 col-sm-6 col-md-3">
<div class="h5 mb-3">Хекслет</div>
<ul class="list-unstyled">
<li>
<a class="nav-link link-light py-1 ps-0" href="/pages/about">О нас</a>
</li>
<li>
<a class="nav-link link-light py-1 ps-0" href="/testimonials">Отзывы</a>
</li>
<li>
<span class="nav-link link-light py-1 ps-0 external-link" data-href="https://b2b.hexlet.io" role="button">Корпоративное обучение</span>
</li>
<li>
<a class="nav-link link-light py-1 ps-0" href="/blog">Блог</a>
</li>
<li>
<a class="nav-link link-light py-1 ps-0" href="/qna">Вопросы и ответы</a>
</li>
<li>
<a class="nav-link link-light py-1 ps-0" href="/glossary">Глоссарий</a>
</li>
<li>
<span class="nav-link link-light py-1 ps-0 external-link" data-href="https://help.hexlet.io" data-target="_blank" role="button">Справка</span>
</li>
<li>
<a class="nav-link link-light py-1 ps-0" target="_blank" rel="noopener noreferrer" href="/map">Карта сайта</a>
</li>
</ul>
</div>
<div class="col-12 col-sm-6 col-md-3">
<div class="h5 fw-normal mb-3">Направления</div>
<ul class="list-unstyled">
<li>
<a class="nav-link link-light py-1 ps-0" href="/courses_devops">DevOps
</a></li>
<li>
<a class="nav-link link-light py-1 ps-0" href="/courses_data_analytics">Аналитика
</a></li>
<li>
<a class="nav-link link-light py-1 ps-0" href="/courses_backend_development">Бэкенд
</a></li>
<li>
<a class="nav-link link-light py-1 ps-0" href="/courses_programming">Программирование
</a></li>
<li>
<a class="nav-link link-light py-1 ps-0" href="/courses_testing">Тестирование
</a></li>
<li>
<a class="nav-link link-light py-1 ps-0" href="/courses_front_end_dev">Фронтенд
</a></li>
</ul>
</div>
<div class="col-12 col-sm-6 col-md-3">
<div class="h5">Профессии</div>
<ul class="list-unstyled">
<li>
<a class="nav-link link-light py-1 ps-0" href="/programs/devops-engineer-from-scratch">DevOps-инженер с нуля</a>
</li>
<li>
<a class="nav-link link-light py-1 ps-0" href="/programs/go">Go-разработчик</a>
</li>
<li>
<a class="nav-link link-light py-1 ps-0" href="/programs/java">Java-разработчик</a>
</li>
<li>
<a class="nav-link link-light py-1 ps-0" href="/programs/python">Python-разработчик </a>
</li>
<li>
<a class="nav-link link-light py-1 ps-0" href="/programs/data-analytics">Аналитик данных</a>
</li>
<li>
<a class="nav-link link-light py-1 ps-0" href="/programs/qa-engineer">Инженер по ручному тестированию</a>
</li>
<li>
<a class="nav-link link-light py-1 ps-0" href="/programs/php">РНР-разработчик</a>
</li>
<li>
<a class="nav-link link-light py-1 ps-0" href="/programs/frontend">Фронтенд-разработчик</a>
</li>
</ul>
</div>
<div class="col-12 col-sm-6 col-md-3">
<div class="h5">Навыки</div>
<ul class="list-unstyled">
<li>
<a class="nav-link link-light py-1 ps-0" href="/programs/python-django-developer">Django</a>
</li>
<li>
<a class="nav-link link-light py-1 ps-0" href="/programs/docker">Docker</a>
</li>
<li>
<a class="nav-link link-light py-1 ps-0" href="/programs/php-laravel-developer">Laravel</a>
</li>
<li>
<a class="nav-link link-light py-1 ps-0" href="/programs/postman">Postman</a>
</li>
<li>
<a class="nav-link link-light py-1 ps-0" href="/programs/js-react-developer">React</a>
</li>
<li>
<a class="nav-link link-light py-1 ps-0" href="/programs/js-rest-api">REST API в Node.js</a>
</li>
<li>
<a class="nav-link link-light py-1 ps-0" href="/programs/spring-boot">Spring Boot</a>
</li>
<li>
<a class="nav-link link-light py-1 ps-0" href="/programs/typescript">Typescript</a>
</li>
</ul>
</div>
</div>
<hr>
<div class="row">
<div class="col-12 col-sm-4 col-md-2">
<div class="fs-4">
<ul class="list-unstyled d-flex">
<li class="me-3">
<a aria-label="Telegram" target="_blank" class="link-light" rel="noopener noreferrer nofollow" href="https://t.me/hexlet_ru"><span class="bi bi-telegram"></span>
</a></li>
<li>
<a aria-label="Youtube" target="_blank" class="link-light" rel="noopener noreferrer nofollow" href="https://www.youtube.com/user/HexletUniversity"><span class="bi bi-youtube"></span>
</a></li>
</ul>
</div>
<div class="mb-2 d-flex flex-column">
<a class="link-light text-decoration-none" rel="nofollow" href="mailto:support@hexlet.io">support@hexlet.io</a>
<a class="link-light text-decoration-none py-2" target="_blank" href="https://t.me/hexlet_help_bot">t.me/hexlet_help_bot</a>
</div>
<ul class="list-unstyled d-flex">
<li class="me-3">
<span class="link-light text-decoration-none opacity-50 x-font-size-18 external-link" rel="nofollow" data-href="https://hexlet.io/locale/switch?new_locale=en" data-target="_self" role="button"><span class="my-auto">EN</span>
</span></li>
<li class="me-3">
<span class="link-light text-decoration-none opacity-50 x-font-size-18 opacity-100 external-link" rel="nofollow" data-href="https://ru.hexlet.io/locale/switch?new_locale=ru" data-target="_self" role="button"><span class="my-auto">RU</span>
</span></li>
<li class="me-3">
<span class="link-light text-decoration-none opacity-50 x-font-size-18 external-link" rel="nofollow" data-href="https://kz.hexlet.io/locale/switch?new_locale=kz" data-target="_self" role="button"><span class="my-auto">KZ</span>
</span></li>
</ul>
</div>
<div class="col-12 col-sm-4 col-md-3">
<ul class="list-unstyled fs-4">
<li class="mb-3">
<a class="link-light text-decoration-none" href="tel:8%20800%20100%2022%2047">8 800 100 22 47</a>
<span class="d-block opacity-50 small">бесплатно по РФ</span>
</li>
<li>
<a class="link-light text-decoration-none" href="tel:%2B7%20495%20085%2021%2062">+7 495 085 21 62</a>
<span class="d-block opacity-50 small">бесплатно по Москве</span>
</li>
</ul>
</div>
<div class="col-12 col-sm-4 col-md-3">
<div class="small mb-3">Образовательные услуги оказываются на основании Л035-01298-77/01989008 от 14.03.2025</div>
<ul class="list-unstyled small">
<li>
<a class="nav-link link-light py-1 ps-0" href="/pages/legal">Правовая информация</a>
</li>
<li>
<a class="nav-link link-light py-1 ps-0" href="/pages/offer">Оферта</a>
</li>
<li>
<a class="nav-link link-light py-1 ps-0" href="/pages/license">Лицензия</a>
</li>
<li>
<a class="nav-link link-light py-1 ps-0" href="/pages/contacts">Контакты</a>
</li>
</ul>
</div>
<div class="col-12 col-sm-12 col-md-4 small">
<div class="mb-2">
<div>ООО «<a href="/" class="text-decoration-none link-light">Хекслет Рус</a>»</div>
<div>108813 г. Москва, вн.тер.г. поселение Московский,</div>
<div>г. Московский, ул. Солнечная, д. 3А, стр. 1, помещ. 20Б/3</div>
<div>ОГРН 1217300010476</div>
<div>ИНН 7325174845</div>
</div>
<hr>
<div>АНО ДПО «<a href="/" class="text-decoration-none link-light">Учебный центр «Хекслет</a>»</div>
<div>119331 г. Москва, вн. тер. г. муниципальный округ</div>
<div>Ломоносовский, пр-кт Вернадского, д. 29</div>
<div>ОГРН 1247700712390</div>
<div>ИНН 7736364948</div>
</div>
</div>
</footer>
<div id="root-assistant-offcanvas"></div>
<script src="/vite/assets/assistant-D8AK0-_C.js" crossorigin="anonymous" type="module"></script><link rel="modulepreload" href="/vite/assets/chunk-DsPFFUou.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/init-DOv3_-Z_.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/ErrorFallbackBlock-naDSYSy9.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/MarkdownBlock-DbyKWoR_.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/gon-D3e4yh1x.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/mantine-CGMYrt2Y.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/shiki-V011pkdv.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/utils-DRqSHbQE.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/routes-CCH8ilKF.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/lib-XR8Qr8kR.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/dist-GCHh59xr.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/Box-B5-OOzBf.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/notifications.store-C-3AFSMn.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/useIsomorphicEffect-HJ6VK0D3.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/lib-KSp6QbZ0.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/axios-BEvgo0ym.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/classnames-l6ipYlLR.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/dayjs.min-BkKovM-s.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/debounce-jMQ_Cf4f.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/i18next-BlSq9s7B.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/client-U9M77rxp.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/react-dom-DaLxUz_h.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/useTranslation-Bx1Cdrkz.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/compiler-runtime-6XxiPFnt.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/jsx-runtime-CwjcCKJi.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/react-CkL4ZRHB.js" as="script" crossorigin="anonymous">
<script defer src="https://static.cloudflareinsights.com/beacon.min.js/v67327c56f0bb4ef8b305cae61679db8f1769101564043" integrity="sha512-rdcWY47ByXd76cbCFzznIcEaCN71jqkWBBqlwhF1SY7KubdLKZiEGeP7AyieKZlGP9hbY/MhGrwXzJC/HulNyg==" data-cf-beacon='{"version":"2024.11.0","token":"d11015b65d11429ea6b4a2ef37dd7e0b","server_timing":{"name":{"cfCacheStatus":true,"cfEdge":true,"cfExtPri":true,"cfL4":true,"cfOrigin":true,"cfSpeedBrain":true},"location_startswith":null}}' crossorigin="anonymous"></script>
</body>
</html>