diff --git a/docs/10.8-perf.ko-KR.md b/docs/10.8-perf.ko-KR.md new file mode 100644 index 00000000..2ff3a7d2 --- /dev/null +++ b/docs/10.8-perf.ko-KR.md @@ -0,0 +1,72 @@ +--- +id: perf-ko-KR +title: 성능 도구 +permalink: perf-ko-KR.html +prev: pure-render-mixin-ko-KR.html +next: advanced-performance-ko-KR.html +--- + +React는 보통 처음에는 꽤 빠릅니다. 하지만 모든 성능을 짜내야 하는 상황일 때를 위해, React는 [shouldComponentUpdate](/react/docs/component-specs.html#updating-shouldcomponentupdate) 훅을 제공해 React의 diff 알고리즘을 위한 최적화 힌트를 추가할 수 있습니다. + +덧붙여 앱의 전반적인 성능의 개요도 제공합니다. ReactPerf는 프로파일링 도구로 정확히 어디에 훅이 필요한지 알려줍니다. + +> 주의: +> +> React의 개발 빌드는 제공되는 추가 기능으로 인해 프로덕션 빌드보다 느립니다. 추가 기능에는 React의 친절한 콘솔 경고같은 것이 있습니다.(이는 프로덕션 빌드에서는 제거 됩니다) 따라서, 프로파일러는 앱의 _상대적으로_ 비싼 부분만 표시하도록 합니다. + +## 일반 API + +여기에서 설명하는 `Perf` 객체는 `react-with-addons.js`를 사용해 개발 모드에서 빌드될 때 `React.addons.Perf`로 노출됩니다. + +### `Perf.start()`와 `Perf.stop()` +측정을 시작/정지합니다. 그 사이의 React 연산은 밑에 있는 분석을 하기위해 기록됩니다. 미미한 양의 연산은 무시됩니다. + +### `Perf.printInclusive(measurements)` +전 수행 시간을 출력합니다. 인자가 넘겨지지 않으면, 기본값은 지난 기록부터의 모든 측정이 됩니다. 이 출력은 밑에 있는 것처럼 콘솔에서 깔끔한 테이블로 그려집니다. + +![](/react/img/docs/perf-inclusive.png) + +### `Perf.printExclusive(measurements)` +컴포넌트를 마운트하는 시간을 포함하지 않은 "exclusive" 시간입니다. 여기에는 props 연산, `getInitialState`, `componentWillMount` 호출, `componentDidMount`등이 포함됩니다. + +![](/react/img/docs/perf-exclusive.png) + +### `Perf.printWasted(measurements)` + +**프로파일러에서 가장 유용한 부분입니다**. + +렌더가 같아서, DOM을 변경(touch)하지 않는 경우같은 실제로는 아무것도 렌더하지 않는 컴포넌트가 사용하는 "낭비되는" 시간을 출력합니다. + +![](/react/img/docs/perf-wasted.png) + +### `Perf.printDOM(measurements)` +"set innerHTML"이나 "remove"같은 기저의 DOM 조작을 출력합니다. + +![](/react/img/docs/perf-dom.png) + +## 고급 API + +위의 출력 메소드에 `Perf.getLastMeasurements()`를 사용해 결과를 이쁘게 출력합니다. + +### `Perf.getLastMeasurements()` +마지막 start-stop 세션에서 측정들의 배열을 가져옵니다. 이 배열은 이런 객체들을 가지고 있습니다. + +```js +{ + // 용어 "inclusive"와 "exclusive"는 위에서 설명했음 + "exclusive": {}, + // '.0.0'는 노드의 React ID + "inclusive": {".0.0": 0.0670000008540228, ".0": 0.3259999939473346}, + "render": {".0": 0.036999990697950125, ".0.0": 0.010000003385357559}, + // 인스턴스의 수 + "counts": {".0": 1, ".0.0": 1}, + // DOM 변경(touch) + "writes": {}, + // 추가 디버깅 정보 + "displayNames": { + ".0": {"current": "App", "owner": ""}, + ".0.0": {"current": "Box", "owner": "App"} + }, + "totalTime": 0.48499999684281647 +} +```