frontend

Critical Rendering Path 보기

2023. 6. 11. 13:44
목차
  1. 😐Critical Rendering Path란?
  2. 😑DOM??
  3. 🤣Critical Rendering Path에 대한 이해
  4. 🤗결론
  5. 🤤레퍼런스

😐Critical Rendering Path란?

MDN의 정의에 따르면 Critical Rendring Path는 브라우저가 HTML, CSS , JavaScript를 화면의 픽셀로 변환하기 위해 거치는 일련의 단계를 뜻합니다.

이 Critical Rendering Path를 최적화하면 렌더링 성능이 향상됩니다.

 

또한 Critical Rendering Path에 해당되는 것으로는

DOM , CSSOM, 렌더링트리, 레이아웃이 있습니다.


😑DOM??

Document Object Model의 줄임말로 HTML이 파싱될때 생성됩니다.

HTML은 JavaScript를 요청할 수 있고 JavaScript는 차례로 DOM을 변경할 수 있습니다.


🤣Critical Rendering Path에 대한 이해

웹의 성능을 구성하는 요소로는

서버 요청 및 응답

로드

스크립팅

렌더링

픽셀페인팅

이 포함될 수 있습니다.

 

CRP의 이해를 위해 브라우저에 우리의 화면이 그려지는 일련의 과정을 생각해보면 다음과 같습니다.

1. 웹페이지 또는 앱에 대한 요청은 HTML 파일을 요청하는 것으로부터 시작합니다.

2. 서버는 HTML파일을 반환합니다.

3. 브라우저는 HTML 파일을 구문분석하며 이를 기반으로 DOM트리를 구성합니다.

4. 이때 브라우저는 구문분석과정에서 스타일시트, 스크립트, 이미지 참조와 같이 외부 리소스에 대한 링크를 찾게되면 이에대한 요청을 시작합니다.

5. 4번 과정에서 리소스의 처리가 완료될 때 까지 HTML 파싱은 블로킹됩니다.

6. 5번까지의 과정을 거치며 DOM을 완성하면 CSSOM을 구축합니다.

7. DOM 및 CSSOM이 완성되면 이를 기반으로 렌더트리를 구축합니다.

8. 7번 과정에서 표시되는 콘텐츠의 스타일을 계산합니다.

9. 렌더트리가 완성되면 레이아웃이 발생하여 모든 렌더 트리 요소의 위치와 크기를 정의합니다.


🤗결론

이거 브라우저 렌더링 과정아닌가..?

ㅎㅎ;;


🤤레퍼런스

https://developer.mozilla.org/en-US/docs/Web/Performance/Critical_rendering_path

 

Critical rendering path - Web performance | MDN

The Critical Rendering Path is the sequence of steps the browser goes through to convert the HTML, CSS, and JavaScript into pixels on the screen. Optimizing the critical render path improves render performance. The critical rendering path includes the Docu

developer.mozilla.org

https://beomy.github.io/tech/browser/critical-rendering-path/

 

[Browser] Critical Rendering Path 최적화

브라우저 렌더링 최적화 방법에 대해 이야기할 것입니다.

beomy.github.io

 

반응형
저작자표시 비영리

'frontend' 카테고리의 다른 글

CloudFlare를 이용해 Next.js 프로젝트 Static하게 배포하기  (2) 2023.06.27
next.js를 활용해 자체 블로그 만들기  (4) 2023.06.25
webpack proxy 설정 에러 해결방법..  (0) 2023.06.07
Github Action으로 S3 배포 자동화하기  (0) 2023.06.05
AWS EC2에서 git ssh key 생성하고 사용하기..  (0) 2023.06.04
  1. 😐Critical Rendering Path란?
  2. 😑DOM??
  3. 🤣Critical Rendering Path에 대한 이해
  4. 🤗결론
  5. 🤤레퍼런스
'frontend' 카테고리의 다른 글
  • CloudFlare를 이용해 Next.js 프로젝트 Static하게 배포하기
  • next.js를 활용해 자체 블로그 만들기
  • webpack proxy 설정 에러 해결방법..
  • Github Action으로 S3 배포 자동화하기
냠냠맨
냠냠맨
프론트엔드 개발 전반을 다루는 기술 블로그입니다.
냠냠맨
React와 TypeScript를 좋아하는 개발자
냠냠맨
전체
오늘
어제
  • all category (433)
    • CMC (0)
    • best (11)
    • 년간회고 (1)
    • cheetsheet (15)
    • 프로젝트 회고 (3)
    • 서평 (3)
    • SEO Study (1)
    • 프로젝트 진행기 (10)
    • testcode (9)
    • yarnberry (7)
    • css (21)
    • typescript (15)
    • redux (7)
    • react (43)
    • Next.js (9)
    • Nestjs (3)
    • javascript (44)
    • programmers (67)
    • leetcode (41)
    • frontend (41)
    • backjoon (1)
    • Next.js Beta Docs 번역 (12)
    • TIL (15)
      • html (3)
    • Network (12)
      • 간단 정리 시리즈 (2)
      • 질답 준비 (0)
    • 자료구조와 알고리즘 (2)
    • CS (4)
      • OS (1)
    • 취업준비 (2)
    • zoom websocket (2)
    • talk (6)
    • 면접대비 (1)
    • 코드스테이츠 프론트 (5)
    • 간헐적 회고 (17)

블로그 메뉴

  • leetcode
  • programmers
  • javascript
  • html
  • css

공지사항

인기 글

태그

  • 코드스테이츠 #프론트엔드
  • 프론트엔드
  • 테오의스프린트
  • 주니어개발자
  • 개발
  • border말풍선
  • frontend
  • 말풍선
  • 테오의스프린트17기
  • teosprint
  • 개발자
  • JavaScript
  • LeetCode
  • CSS

최근 댓글

최근 글

hELLO · Designed By 정상우.
냠냠맨
Critical Rendering Path 보기
상단으로

티스토리툴바

개인정보

  • 티스토리 홈
  • 포럼
  • 로그인

단축키

내 블로그

내 블로그 - 관리자 홈 전환
Q
Q
새 글 쓰기
W
W

블로그 게시글

글 수정 (권한 있는 경우)
E
E
댓글 영역으로 이동
C
C

모든 영역

이 페이지의 URL 복사
S
S
맨 위로 이동
T
T
티스토리 홈 이동
H
H
단축키 안내
Shift + /
⇧ + /

* 단축키는 한글/영문 대소문자로 이용 가능하며, 티스토리 기본 도메인에서만 동작합니다.