[React] ๋ฆฌ์กํธ์์ Rendering ๋ ๋๋ง์ด๋?
TL;DR
- ๋ง์ดํธ : ์ปดํฌ๋ํธ๊ฐ ์ต์ด๋ก DOM์ ์ฝ์ ๋๋ ๊ณผ์ . ์ปดํฌ๋ํธ ์๋ช ์ฃผ๊ธฐ์์ ํ ๋ฒ๋ง ๋ฐ์
- ๋ ๋ : ์ปดํฌ๋ํธ๋ฅผ ์คํํด์ ๋ณ๊ฒฝ์ฌํญ์ ๊ณ์ฐ(์ปดํฌ๋ํธ ์ถ๋ ฅ ๊ฒฐ์ )ํ๋ ๊ณผ์ . ์๋ก์ด ๊ฐ์ DOM์ ์์ฑํ๊ณ ์ด ์๋ก์ด ๊ฐ์ DOM๊ณผ ์ด์ ๊ฐ์ DOM์ ๋น๊ตํ์ฌ ์ค์ DOM์ ๋ฐ์ํ ๋ณ๊ฒฝ์ฌํญ ํ์
- ์ปค๋ฐ : ๋ ๋ ๋จ๊ณ๋ฅผ ํตํด ํ์ ๋ ๋ณ๊ฒฝ์ฌํญ๋ค์ด ์ค์ ๋ธ๋ผ์ฐ์ DOM์ ์ ์ฉ๋๋ ๊ณผ์
๋ ๋๋ง์ด๋
์ผ๋ฐ์ ์ผ๋ก ๋ ๋๋ง(Rendering)์ ์๋ 2๊ฐ์ง ๊ณผ์ ์ ์ง์นญํ๋ค.
- HTML / CSS / JS๋ก ์์ฑ๋ ๋ฌธ์๋ฅผ ํด์(ํ์ฑ)ํด์ ๋ธ๋ผ์ฐ์ ์ ์๊ฐ์ ์ผ๋ก ์ถ๋ ฅํ๋ ๊ณผ์
- ์๋ฒ์์ ๋ฐ์ดํฐ๋ฅผ HTML๋ก ๋ณํํด์ ๋ธ๋ผ์ฐ์ ์๊ฒ ์ ๋ฌํ๋ ๊ณผ์ (SSR)
๋ฐ๋ฉด ๋ฆฌ์กํธ์์ ๋งํ๋ ๋ ๋๋ง์ ๋ธ๋ผ์ฐ์ DOM ์์ ๋น์ฉ์ ์ค์ด๊ธฐ ์ํด ์ํํ๋ ์์ ์ ์ผ์ปซ๋๋ค. ์ด ์์ ์ ํตํด ๋ธ๋ผ์ฐ์ DOM์ ์ ๋ฐ์ดํธ ๋ฒ์๋ฅผ ๊ฒฐ์ ํ๊ณ ๋ฐ์ํ๋ค. ์ข ๋ ์๋ฐํ๊ฒ ๋งํ๋ฉด props์ state๋ฅผ ๊ธฐ๋ฐ์ผ๋ก UI ์์ญ์ด ์ด๋ป๊ฒ ๋ณด์ด๊ธธ ์ํ๋์ง, ์ปดํฌ๋ํธ์๊ฒ ์ค๋ช ์ ์์ฒญํ๋ ๋ฆฌ์กํธ ํ๋ก์ธ์ค๋ค.
Rendering is the process of React asking your components to describe what they want their section of the UI to look like now, based on the current combination of props and state
๋ ๋๋ง ๊ณผ์
โถ Trigger: ๋ ๋๋ง ์ ๋ฐ
์ฑ ์์ ์ด๊ธฐ(initial render) ๋๋ state ๋ณ๊ฒฝ์ด ์์ ๋(re-render).
โท Render: ์ปดํฌ๋ํธ๋ฅผ ๋ ๋๋งํ๊ณ ๋ณ๊ฒฝ์ฌํญ ๊ณ์ฐ
๋ธ๋ผ์ฐ์ DOM์ ๋ฐ์๋ ์์๋ฅผ ๊ณ์ฐํ๋ค. ์ด ๋จ๊ณ์์ ๋ธ๋ผ์ฐ์ DOM์ ์ ๋ฐ์ดํธ ํ๊ธฐ ์ , ๊ฐ์ DOM์ ์กฐ์ํด์ ์ ๋ฐ์ดํธํ ๋ชจ์์ ๋ง๋ค์ด ๋ธ๋ค. ๋ธ๋ผ์ฐ์ DOM์ ์ง์ ์กฐ์ํ๋ ๋น์ฉ(repaint / reflow)์ด ํฌ๊ธฐ ๋๋ฌธ์ ๊ฐ์ DOM์ ํตํด ์ ๋ฐ์ดํธ๋ฅผ ๋ฏธ๋ฆฌ ์คํํ๋ ๊ฒ. ์ด๊ธฐ ๋ ๋๋ผ๋ฉด ๋ฃจํธ ์ปดํฌ๋ํธ๋ฅผ ํธ์ถํด์ ์ ์ฒด ์๋ฆฌ๋จผํธ์ ๋ํ ๊ฐ์๋์ ๋ง๋ค๊ณ , ๋ฆฌ๋ ๋๋ผ๋ฉด ์ด์ ๋ ๋์ ๋น๊ตํด์ ๋ณํ๊ฐ ์๋ ์ปดํฌ๋ํธ๋ฅผ ํธ์ถํ๋ค.
โธ Commit: ๋ ๋ ๋จ๊ณ์์ ๊ณ์ฐ๋ ๋ณ๊ฒฝ์ฌํญ์ DOM์ ์ ์ฉ
Render ๋จ๊ณ๋ฅผ ํตํด ํธ์ถ๋ ์ปดํฌ๋ํธ๋ค์ด ๋ธ๋ผ์ฐ์ DOM์ ์ ์ฉ๋๋ ๋จ๊ณ. ๋ ๋ ๋จ๊ณ์์ ๋ณํ๊ฐ ์์๋ ๋ถ๋ถ๋ง DOM์ ๋ง์ดํธ๋๊ณ ๋ผ์ดํ์ฌ์ดํด์ ์คํํ๋ค.
์ฌ์กฐ์ | Reconciliation
React๋ ๋ ๋๋ง ํ๋ก์ธ์ค ๋์ ์ปดํฌ๋ํธ ํธ๋ฆฌ ์ ์ฒด์์ ๋ ๋๋ง ๊ฒฐ๊ณผ๋ฌผ์ ์์งํ๋ค. ๊ทธ ํ ์๋ก์ด ๊ฐ์ฒด ํธ๋ฆฌ(๊ฐ์ DOM)์ ๋น๊ตํ์ฌ ๋ธ๋ผ์ฐ์ DOM์ ์ํ๋ ์ถ๋ ฅ์ผ๋ก ๋ณด์ด๊ธฐ ์ํด ๋ชจ๋ ๋ณ๊ฒฝ์ฌํญ์ ์์งํ๋ค. ๋ฆฌ์กํธ์์ ์ด๋ ๊ฒ ๋น๊ตํ๊ณ ๊ณ์ฐํ๋ ๊ณผ์ ์ ์ฌ์กฐ์ (reconciliation)์ด๋ผ๊ณ ๋ถ๋ฅธ๋ค.
React === value UI
๋ฆฌ์กํธ๋ ๊ฐ(value) UI๋ค. ์ฆ, UI๋ฅผ ๋ฌธ์์ด์ด๋ ๋ฐฐ์ด๊ณผ ๊ฐ์ ๊ฐ์ผ๋ก ๋ณด๋ ๊ฐ๋ ์ด๋ค. ๊ฐ์ ๋ณ์์ ์ ์ฅํ๊ฑฐ๋ ์ ๋ฌํ๊ณ , ์๋ฐ์คํฌ๋ฆฝํธ ์ ์ด ํ๋ฆ์์ ์ฌ์ฉํ ์ ์๋ค. ์ด์ฒ๋ผ UI๋ฅผ ๊ฐ์ฒ๋ผ ์ ์ดํ๋ ๋ฐฉ์์ด ๋ ๋๋ง ํ๋ก์ธ์ค์ ์ฃผ์ ํฌ์ธํธ๋ค.
React is โvalue UIโ. Its core principle is that UI is a value, just like a string or an array. You can keep it in a variable, pass it around, use JavaScript control flow with it, and so on. That expressiveness is the point โ not some diffing to avoid applying changes to the DOM.
โ via Markโs Dev Blog
๋ ํผ๋ฐ์ค
- (๋ฒ์ญ) ๋ธ๋ก๊ทธ ๋ต๋ณ: React ๋ ๋๋ง ๋์์ ๋ํ (๊ฑฐ์) ์๋ฒฝํ ๊ฐ์ด๋
- ๋ฆฌ์กํธ์์ "๋ ๋๋ง(rendering)"์ ์ด๋ค ์๋ฏธ์ธ๊ฐ์?
๊ธ ์์ ์ฌํญ์ ๋ ธ์ ํ์ด์ง์ ๊ฐ์ฅ ๋น ๋ฅด๊ฒ ๋ฐ์๋ฉ๋๋ค. ๋งํฌ๋ฅผ ์ฐธ๊ณ ํด ์ฃผ์ธ์
'๐ช Programming' ์นดํ ๊ณ ๋ฆฌ์ ๋ค๋ฅธ ๊ธ
[JS] ๋ฌธ์ฅ, ๋จ์ด, ์์๋ณ๋ก ๋ฌธ์์ด ๋ถ๋ฆฌํ๊ธฐ (0) | 2024.05.17 |
---|---|
[TS] ํ์ ์คํฌ๋ฆฝํธ์ ๊ณต๋ณ์ฑ / ๋ฐ๊ณต๋ณ์ฑ / ์ด๋ณ์ฑ (0) | 2024.05.17 |
[TS] TypeScript ํ์ ์คํฌ๋ฆฝํธ satisfies ์ฐ์ฐ์ (0) | 2024.05.16 |
[React/JS] Promise ํ๋ก๋ฏธ์ค๋ฅผ ํ์ฉํ UX ๊ฐ์ โ ํด ๋ฏธ๋ฃจ๊ธฐ (0) | 2024.05.16 |
[React] ๋ฆฌ์กํธ Profiler ํ๋กํ์ผ๋ฌ์ Hook ์์ (0) | 2024.05.16 |
๋๊ธ
์ด ๊ธ ๊ณต์ ํ๊ธฐ
-
๊ตฌ๋
ํ๊ธฐ
๊ตฌ๋ ํ๊ธฐ
-
์นด์นด์คํก
์นด์นด์คํก
-
๋ผ์ธ
๋ผ์ธ
-
ํธ์ํฐ
ํธ์ํฐ
-
Facebook
Facebook
-
์นด์นด์ค์คํ ๋ฆฌ
์นด์นด์ค์คํ ๋ฆฌ
-
๋ฐด๋
๋ฐด๋
-
๋ค์ด๋ฒ ๋ธ๋ก๊ทธ
๋ค์ด๋ฒ ๋ธ๋ก๊ทธ
-
Pocket
Pocket
-
Evernote
Evernote
๋ค๋ฅธ ๊ธ
-
[JS] ๋ฌธ์ฅ, ๋จ์ด, ์์๋ณ๋ก ๋ฌธ์์ด ๋ถ๋ฆฌํ๊ธฐ
[JS] ๋ฌธ์ฅ, ๋จ์ด, ์์๋ณ๋ก ๋ฌธ์์ด ๋ถ๋ฆฌํ๊ธฐ
2024.05.17 -
[TS] ํ์ ์คํฌ๋ฆฝํธ์ ๊ณต๋ณ์ฑ / ๋ฐ๊ณต๋ณ์ฑ / ์ด๋ณ์ฑ
[TS] ํ์ ์คํฌ๋ฆฝํธ์ ๊ณต๋ณ์ฑ / ๋ฐ๊ณต๋ณ์ฑ / ์ด๋ณ์ฑ
2024.05.17 -
[TS] TypeScript ํ์ ์คํฌ๋ฆฝํธ satisfies ์ฐ์ฐ์
[TS] TypeScript ํ์ ์คํฌ๋ฆฝํธ satisfies ์ฐ์ฐ์
2024.05.16 -
[React/JS] Promise ํ๋ก๋ฏธ์ค๋ฅผ ํ์ฉํ UX ๊ฐ์ โ ํด ๋ฏธ๋ฃจ๊ธฐ
[React/JS] Promise ํ๋ก๋ฏธ์ค๋ฅผ ํ์ฉํ UX ๊ฐ์ โ ํด ๋ฏธ๋ฃจ๊ธฐ
2024.05.16
๋๊ธ์ ์ฌ์ฉํ ์ ์์ต๋๋ค.