[Observer API ํํค์น๊ธฐ] 6. ReportingObserver
โฐ 2024-06-30 (์ผ) 02:08:13
Observer API ํํค์น๊ธฐ
6 / 6
Table of Contents
ReportingObserver
ReportingObserver
๋ ์น ๋ธ๋ผ์ฐ์ ์ ์ฑ๋ฅ ๋ฐ ์ฌ์ฉ์ฑ, ์์ ์ฑ ์์๋ฅผ ๊ฐ์งํ๋ ์ต์ ๋ฒ๋ค. ํ์ด์ง์์ ๋ฐ์ํ ์ ์๋ ๋ฌธ์ ์ ์ ์ค์๊ฐ์ผ๋ก ๋ชจ๋ํฐ๋งํ ๋ ์ ์ฉํ๊ฒ ์ฌ์ฉํ ์ ์๋ค.
TYPESCRIPT
1 2 3
const ro = new ReportingObserver(callback, options); ro.observe();
options
์ต์ ๋ฒ ์ ์ธ ์, options
์ ์ ๋ฌํ์ฌ ์ธ๋ถ ์ฌํญ์ ์กฐ์ ํ ์ ์๋ค. ReportingObserverOptions
ํ์
์ ๊ฐ์ง๋ค.
๋ณด๊ณ ์ ํ์
(types)
์ต์ ๋ฒ์์ ์ ๊ณตํ ๋ณด๊ณ ์ ํ์
์ ๋ฐฐ์ด๋ก ์ง์ ํ๋ค. ์ง์ ๊ฐ๋ฅํ ๊ฐ์ deprecation
, intervention
๋ ๊ฐ์ง๋ค.
deprecation
(์ฌ์ฉ ์ค๋จ ๋ณด๊ณ ์): ๋ธ๋ผ์ฐ์ ์์ deprecated ๋๊ฑฐ๋, ๋ ์์ ์ธ ๊ธฐ๋ฅ์ ์ฌ์ฉํ๊ณ ์์ ๊ฒฝ์ฐ, ๊ด๋ จ ๋ณด๊ณ ์๋ฅผ ์ ๊ณตํจ.intervention
(๊ฐ์ ๋ณด๊ณ ์): ๋ธ๋ผ์ฐ์ ๊ฐ ํน์ ๋์์ ๊ฐ์ ํด ๋์์ ์์ ํ๊ฑฐ๋, ์ฐจ๋จํ์ ๊ฒฝ์ฐ, ๊ด๋ จ ๋ณด๊ณ ์๋ฅผ ์ ๊ณตํจ.
๊ธฐ์กด ๋ณด๊ณ ์ ํฌํจ ์ฌ๋ถ (buffered)
ReportingObserver
๊ฐ ์ ์ธ๋๊ธฐ ์ด์ ์ ๋ณด๊ณ ์๋ ํฌํจํ๋์ง ์ฌ๋ถ๋ฅผ ์ง์ ํจ. ๊ธฐ๋ณธ์ ์ผ๋ก false
๊ฐ์ ๊ฐ์ง.
callback
์ฝ๋ฐฑ ๋ฉ์๋๋ก ๊ด๋ จ ๋ณด๊ณ ์๋ฅผ ๋ค๋ฃฐ ์ ์๋ค. ReportingObserverCallback
ํ์
์ ๊ฐ์ง๋ค.
report
๋ฐ์ํ ๋ณด๊ณ ์ ๋ฐฐ์ด์ ๋ฐํํ๋ค. Report
ํ์
์ ๊ฐ์ง๋ค.
type
: ๋ณด๊ณ ์ ํ์ ์ ๋ฐํํ๋ค.deprecation
,intervention
์ค ํ๋๋ฅผ ๊ฐ๋๋ค.url
: ๋ณด๊ณ ์ ๋์ URL์ ๋ฐํํ๋ค. ์ผ๋ฐ์ ์ผ๋ก ํ์ฌ ํ์ด์ง URL์ด ๋ด๊ฒจ์๋ค.body
: ๋ณด๊ณ ์ ๋ด์ฉ์ ๋ฐํํ๋ค. ๊ฐ ๋ณด๊ณ ์์ ๋ฐ๋ผ ๋ด์ฉ์ด ๋ฐ๋๋ค.
observer
์ต์ ๋ฒ ์๊ธฐ ์์ ์ ๋ฐํํ๋ค. ์ด๋ฅผ ํตํด ์ฝ๋ฐฑ ๋ฉ์๋์์ ์ต์ ๋ฒ์ ์ ๊ทผํ ์ ์๋ค.
React์์ ์ปค์คํ
ํ
์ผ๋ก ๊ฐํธํ๊ฒ ์ฌ์ฉํ๊ธฐ
ReportingObserver
๋ฅผ ์ปค์คํ
ํ
์ ํตํด ๊ฐํธํ๊ฒ ์ฌ์ฉํด๋ณด์.
TYPESCRIPT
1 2 3 4
export function useReportingObserver(): void { // }
์์ ๊ฐ์ด useReportingObserver
๋ฉ์๋๋ฅผ ์ ์ํ๋ค.
useReportingObserver
๋ฅผ ์ฌ์ฉํ๊ธฐ ์ํด์ ์๋์ ๋ ์์๊ฐ ํ์ํ๋ค.
- ์ฝ๋ฐฑ ๋ฉ์๋
- ์ต์
PerformanceObserver
์ ๋ง์ฐฌ๊ฐ์ง๋ก DOM์ด ํ์์๋ค.
TYPESCRIPT
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20
import { useEffect } from "react"; export type UseReportingObserverCallback = (entry: Report) => void; /** * ReportingObserver ์ ์ฉ ํ ๋ฉ์๋ * * @param {UseReportingObserverCallback} callback: ์ฝ๋ฐฑ ๋ฉ์๋ * @param {PerformanceObserverInit} options: ์ต์ */ export function useReportingObserver( callback: UseReportingObserverCallback, options?: ReportingObserverOptions ): void { useEffect(() => { const ro = new ReportingObserver((reports) => { reports.forEach(callback); }, options); }, [callback, options]); }
ReportingObserver
๋ฅผ ์ด๊ธฐํํ์ฌ ro
๋ณ์๋ก ํ ๋นํ๋ค.
ro.observe()
๋ฉ์๋๋ฅผ ํตํด ํ๊ทธ๋ฅผ ๋ฑ๋กํ ์ ์๋ค.
TYPESCRIPT
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22
import { useEffect } from "react"; export type UseReportingObserverCallback = (entry: Report) => void; /** * ReportingObserver ์ ์ฉ ํ ๋ฉ์๋ * * @param {UseReportingObserverCallback} callback: ์ฝ๋ฐฑ ๋ฉ์๋ * @param {PerformanceObserverInit} options: ์ต์ */ export function useReportingObserver( callback: UseReportingObserverCallback, options?: ReportingObserverOptions ): void { useEffect(() => { const ro = new ReportingObserver((reports) => { reports.forEach(callback); }, options); ro.observe(); }, [callback, options]); }
๋ง์ง๋ง์ผ๋ก, ์ปดํฌ๋ํธ๊ฐ ๋ ๋๋ง ๋ ๋๋ง๋ค ReportingObserver
์ ๋ฑ๋ก์ด ์ค์ฒฉ๋์ง ์๋๋ก, ์ด๊ธฐํ ์ฝ๋๋ฅผ ๋ฃ์ด์ค๋ค.
ro.disconnect()
๋ฉ์๋๋ฅผ ํตํด ReportingObserver
๋ฅผ ์ ๊ฑฐํ ์ ์๋ค.
์ ์ฒด ์ฝ๋
TYPESCRIPT
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26
import { useEffect } from "react"; export type UseReportingObserverCallback = (entry: Report) => void; /** * ReportingObserver ์ ์ฉ ํ ๋ฉ์๋ * * @param {UseReportingObserverCallback} callback: ์ฝ๋ฐฑ ๋ฉ์๋ * @param {PerformanceObserverInit} options: ์ต์ */ export function useReportingObserver( callback: UseReportingObserverCallback, options?: ReportingObserverOptions ): void { useEffect(() => { const ro = new ReportingObserver((reports) => { reports.forEach(callback); }, options); ro.observe(); return () => { ro.disconnect(); }; }, [callback, options]); }
์ ์ฒด ์ฝ๋๋ ์์ ๊ฐ๋ค.
CodeSandbox๋ก ํตํ ์์
CodeSandbox๋ก ๊ฐ๋จํ ์์๋ฅผ ๊ตฌํํ๋ค.
๋ง์น๋ฉฐ
ReportingObserver
๋ ์๋น์ค์์ ๋ฐ์ํ๊ฑฐ๋ ๋ฐ์ํ ์ ์๋ ์ ์ฌ์ ์ธ ์ค๋ฅ๋ฅผ ๋ชจ๋ํฐ๋งํ ์ ์๋ ์ต์ ๋ฒ๋ค.
์ด ์ต์ ๋ฒ๋ฅผ ์ ์ ํ ํ์ฉํ๋ฉด ๊ฐ๋จํ๊ฒ ์์ฒด์ ์ธ ์ค๋ฅ ๋ชจ๋ํฐ๋ง ๋ชจ๋์ ๊ตฌํํ ์ ์์ ๊ฒ์ด๋ค.
๊ทธ๋ฌ๋ ์ด๋ฏธ ์ฝ๋ ํ์ง ๋ฐ ์๋น์ค ์์ ์ฑ์ ๊ฒ์ฆํ๋ ์ฌ๋ฌ ์คํ/์์ฉ ์ํํธ์จ์ด๊ฐ ์กด์ฌํ๊ธฐ๋ ํ๊ณ , ๊ฒฐ์ ์ ์ผ๋ก ReportingObserver
์ ๋ํ ์ ๋ณด๊ฐ ์๋นํ ๋ฏธํกํ๋ค.
์ด ์ต์ ๋ฒ ๋ํ PerformanceObserver
์ ๋ง์ฐฌ๊ฐ์ง๋ก, ์ด๋ฐ ๊ฒ ์๋ค ์ ๋๋ก๋ง ์ง๊ณ ๋์ด๊ฐ๋, ๊ฐ๋ฐ์ ํฐ ์ง์ฅ์ ์์ ๊ฒ์ด๋ผ ์๊ฐํ๋ค.
์๋ฆฌ์ฆ๋ฅผ ๋๋ง์น๋ฉฐ
6ํธ์ ๊ฑธ์น Observer API ์๋ฆฌ์ฆ๊ฐ ์๊ฒฐ๋๋ค. ์ค์ ๋ก ๊ฐ๋ฐ์ ์งํํ๋ฉด์, ๋ช๋ช Event Driven ๊ธฐ๋ฐ์ ์ฝ๋๋ฅผ Observer API๋ก ๋์ฒดํ๊ณ ์๋ค. ์ปดํฌ๋ํธ ๋ฐ ๊ธฐ๋ฅ ๊ฐ๋ฐ์ ์์ด์ ๋์ฑ ํจ์จ์ ์ด๊ณ , ๊ฐํธํ ๋ก์ง์ ๊ตฌํํ๊ธฐ ์ฉ์ดํ๋ ๊ฒ ๊ฐ๋ค.
ํนํ, ์์ฆ ๊ฐ๋ฐํ๋ ๋๋ถ๋ถ์ ๊ฐ์ธ ํ๋ก์ ํธ์, ์ฃผ์ ์ต์ ๋ฒ๋ฅผ React ํ ์ผ๋ก ๋ง๋ค์ด ์ฌ์ฉํ๊ณ ์๋๋ฐ, DOM ๋ฑ๋ก ๊ท์ฐฎ์ ์ฝ๋๋ฅผ ๊ฐ๋จํ๊ฒ ์ค์ผ ์ ์๋ ์ ์ด ๋งค๋ ฅ์ ์ด์๋ค.
์์ผ๋ก ์ข ์ข React ์ปดํฌ๋ํธ์ ๊ด๋ จ๋ ๊ธ์ ์์ฑํ ์์ ์ธ๋ฐ, ์ด์ ์ Observer์ ๊ด๋ จ๋ ๋ด์ฉ์ ์ง๊ณ ๋์ด๊ฐ์ผ ๋ช๋ช ์ปดํฌ๋ํธ ์ค๋ช ์ด ๋งค๋๋ฌ์์ง ๊ฒ์ด๋ผ ํ๋จํ๋ค.
์์ผ๋ก ์์ ์ปดํฌ๋ํธ ์ค๋ช ๊ณผ ๋๋ถ์ด, ์ปดํฌ๋ํธ์ ๊ด๊ณ์์ด ์ด ๊ธ์ ์ฝ๋ ๋ถ๋ค์ด, Observer API๋ฅผ ํตํด ๊ธฐ๋ฅ ๊ฐ๋ฐ์ ๋ ๋ง์ ์ธ์ฌ์ดํธ๋ฅผ ์ป๊ธธ ๋ฐ๋๋ค.
๐ท๏ธ ํ๊ทธ
์ฝ์ด์ฃผ์ ์ ๊ณ ๋ง์์!
๋์์ด ๋์ จ๋ค๋ฉด, ๊ณต๊ฐ์ด๋ ๋๊ธ์ ๋ฌ์์ฃผ์๋ ๊ฑด ์ด๋ค๊ฐ์?
๋ธ๋ก๊ทธ ์ด์์ ํฐ ํ์ด ๋ฉ๋๋ค.