본문 바로가기

Web/Frontend 기본 CS 정리

브라우저 렌더링 과정을 설명해주세요.

728x90

먼저 서버로부터 HTML 문서를 전달받으면, 브라우저 엔진은 위에서 아래로 순차적으로 파싱하며 태그와 속성을 발견합니다.

이 태그와 속성들은 트리 형태로 변환되어 메모리에 저장되는데, 이를 DOM 트리라고 합니다.

HTML 파싱 중 CSS 링크나 스타일 태그를 만나면 이를 파싱하여 CSSOM 트리로 변환합니다.

문서의 파싱이 완료되면 DOM과 CSSOM 트리를 결합하여 렌더 트리를 생성합니다.

렌더 트리는 브라우저 상에서 요소의 위치와 크기를 결정하는 리플로우 과정을 거치며,

마지막으로 요소의 색상, 경계선 등 시각적 요소를 그리는 페인팅 과정이 진행됩니다.

리플로우

  • 웹 페이지 내에서 요소의 위치와 크기를 결정하는 과정

리페인트

  • 요소의 생상 등 시각적 요소를 업데이트하는 과정

HTML 파싱 중간에 script 태그를 만나면 어떻게 되나?

  • 브라우저는 해당 스크립트를 로드하고 실행하기 위해 파싱을 일시 중단합니다.
  • 외부 스크립트의 경우 스크립트를 로드하고 실행한 후 파싱을 재개하며,→ 이로인해 파싱 속도가 저하되고 DOM 트리가 완성되기 전에 스크립트가 DOM을 조작할 가능성이 있어 예기치 못할 상황이 발생할 수 있습니다.
  • 이러한 문제를 방지하기 위해 async나 defer 속성을 사용하여 파싱에 미치는 영향을 최소화할 수 있습니다.
  • 내부 스크립트의 경우 실행이 완료될 때까지 파싱이 중단됩니다.

async와 defer 속성이란?

  • 스크립트를 비동기적으로 로드할 수 있도록 하는 script 태그의 속성
  • 이들은 HTML 파싱이 중단되는 현상과 DOM 트리가 완성되기 전에 스크립트가 실행되는 것을 방지하기 위해 사용됩니다.
  • async
  • 스크립트가 로드되는 즉시 실행, 스크립트 로드 순서가 상관 없을 경우
  • defer
  • HTML 문서 파싱이 완료 후 실행, 스크립트 실행 순서가 중요할 경우