Логотип YeaHub

База вопросов

Собеседования

Тренажёр

База ресурсов

Обучение

Навыки

Войти

Выбери, каким будет IT завтра — вместе c нами!

YeaHub — это полностью открытый проект, призванный объединить и улучшить IT-сферу. Наш исходный код доступен для просмотра на GitHub. Дизайн проекта также открыт для ознакомления в Figma.

© 2026 YeaHub

AI info

Карта сайта

Документы

Медиа

Назад
Вопрос про JavaScript: browser rendering, critical rendering path, DOM, CSSOM, JavaScript execution

Какие этапы проходят HTML, CSS и JavaScript при загрузке страницы?

Вопрос проверяет понимание процесса загрузки и рендеринга веб-страницы браузером, что необходимо для оптимизации производительности.

Короткий ответ

Браузер загружает HTML и начинает его парсинг, строя DOM. При встрече CSS он строит CSSOM, а JavaScript блокирует парсинг до выполнения. Затем DOM и CSSOM объединяются в дерево рендеринга, после чего происходит layout (расчет геометрии) и paint (отрисовка пикселей).

Длинный ответ

Этапы загрузки страницы

Когда браузер получает HTML-документ, он проходит несколько ключевых этапов, чтобы отобразить страницу. Этот процесс называется критическим путем рендеринга (Critical Rendering Path). Понимание этих этапов помогает разработчикам оптимизировать скорость загрузки.

1. Парсинг HTML и построение DOM

Браузер начинает парсить HTML с первого байта. Он преобразует разметку в объектную модель документа (DOM) — дерево узлов, где каждый тег становится элементом. Парсинг идет последовательно, но может быть приостановлен.

2. Загрузка и парсинг CSS (CSSOM)

Когда браузер встречает тег <link> или <style>, он начинает загружать CSS. Парсинг CSS не блокирует построение DOM, но блокирует рендеринг — браузер не покажет страницу, пока не построит CSSOM (объектную модель CSS). CSSOM — это дерево правил, которые применяются к элементам.

3. Влияние JavaScript

JavaScript может блокировать парсинг HTML. Если скрипт встречается без атрибутов async или defer, браузер останавливает построение DOM, загружает и выполняет скрипт, и только потом продолжает. Это может замедлить загрузку. Атрибут defer откладывает выполнение до завершения парсинга, а async выполняет скрипт асинхронно, не блокируя парсинг.

4. Построение дерева рендеринга

После того как DOM и CSSOM готовы, браузер объединяет их в дерево рендеринга. В него попадают только видимые элементы (например, <head> или элементы с display: none исключаются).

5. Layout (Reflow)

На этом этапе браузер вычисляет точные размеры и позиции каждого элемента на странице. Это ресурсоемкий процесс, особенно при сложных макетах.

6. Paint

Финальный этап — преобразование дерева рендеринга в пиксели на экране. Браузер рисует слои, применяет цвета, тени и текстуры.

Пример кода для демонстрации блокировки

<!DOCTYPE html>
<html>
<head>
  <link rel="stylesheet" href="styles.css"> <!-- блокирует рендеринг -->
  <script src="script.js"></script> <!-- блокирует парсинг HTML -->
</head>
<body>
  <p>Текст появится после загрузки скрипта</p>
</body>
</html>

В этом примере браузер сначала загрузит CSS, затем остановится на скрипте, выполнит его, и только потом продолжит парсинг и рендеринг.

Вывод

Понимание этапов загрузки помогает разработчикам оптимизировать производительность: размещать CSS в <head>, а JavaScript — в конце <body> с атрибутами async или defer, чтобы не блокировать рендеринг и улучшить пользовательский опыт.

Frontend developer

tech
tech
tech
tech
tech
tech
tech
tech
tech

Ментор по Frontend

Полное сопровождение до оффера — без дорогих курсов, с оплатой после трудоустройства

Записаться на консультацию

Уровень

  • Рейтинг:

    4

  • Сложность:

    4

Навыки

  • JavaScript

    JavaScript

  • HTML

    HTML

Ключевые слова

#browser rendering

#critical rendering path

#DOM

#CSSOM

#JavaScript execution

Подпишись на React Developer в телеграм

Frontend developer

tech
tech
tech
tech
tech
tech
tech
tech
tech

Ментор по Frontend

Полное сопровождение до оффера — без дорогих курсов, с оплатой после трудоустройства

Записаться на консультацию