You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
216 lines
8.9 KiB
216 lines
8.9 KiB
10 years ago
|
---
|
||
|
id: component-specs-ko-KR
|
||
|
title: 컴포넌트 명세와 생명주기
|
||
|
permalink: component-specs.ko-KR.html
|
||
|
prev: component-api.ko-KR.html
|
||
|
next: tags-and-attributes.ko-KR.html
|
||
|
---
|
||
|
|
||
|
## 컴포넌트 명세
|
||
|
|
||
|
`React.createClass()`를 호출하여 컴포넌트 클래스를 생성할 때, `render` 메소드를 포함한 명세 객체를 제공해야 합니다. 또한 필요한 경우 여기에서 설명하는 다른 생명주기 메소드를 명세 객체에 추가로 제공할 수 있습니다.
|
||
|
|
||
|
|
||
|
### render
|
||
|
|
||
|
```javascript
|
||
|
ReactComponent render()
|
||
|
```
|
||
|
|
||
|
`render()` 메소드는 필수 항목입니다.
|
||
|
|
||
|
호출되면 `this.props`와 `this.state`를 토대로 하나의 자식 컴포넌트를 리턴합니다. 이 자식 컴포넌트는 네이티브 DOM 컴포넌트의 가상 표현 (`<div />`나 `React.DOM.div()` 등) 또는 직접 정의한 조합(composite) 컴포넌트가 될 수 있습니다.
|
||
|
|
||
|
아무 것도 렌더링되지 않도록 하려면 `null`이나 `false`를 리턴합니다. React는 지금의 차이 비교 알고리즘이 작동할 수 있도록 내부적으로는 `<noscript>` 태그를 렌더링합니다. `null`이나 `false`를 리턴한 경우, `this.getDOMNode()`는 `null`을 리턴합니다.
|
||
|
|
||
|
`render()` 함수는 순수 함수여야 합니다. 즉, 컴포넌트의 상태를 변경하지 않고, 여러번 호출해도 같은 결과를 리턴하며, DOM을 읽고 쓰거나 브라우저와 상호작용(예를 들어 `setTimeout`를 사용)하지 않아야 합니다. 브라우저와 상호작용해야 한다면 `componentDidMount()`나 다른 생명주기 메소드에서 수행해야 합니다. `render()` 함수를 순수 함수로 유지하면 서버 렌더링이 훨씬 쓸만해지고 컴포넌트에 대해 생각하기 쉬워집니다.
|
||
|
|
||
|
|
||
|
### getInitialState
|
||
|
|
||
|
```javascript
|
||
|
object getInitialState()
|
||
|
```
|
||
|
|
||
|
컴포넌트가 마운트되기 전에 한번 호출됩니다. 리턴값은 `this.state`의 초기값으로 사용됩니다.
|
||
|
|
||
|
|
||
|
### getDefaultProps
|
||
|
|
||
|
```javascript
|
||
|
object getDefaultProps()
|
||
|
```
|
||
|
|
||
|
클래스가 생성될 때 한번 호출되고 캐시됩니다. 부모 컴포넌트에서 prop이 넘어오지 않은 경우 (`in` 연산자로 확인) 매핑의 값이 `this.props`에 설정됩니다.
|
||
|
|
||
|
이 메소드는 인스턴스가 만들어지기 전에 호출되므로 `this.props`에 의존할 수 없습니다. 그리고 `getDefaultProps()`의 리턴값에 포함된 복잡한 객체는 복사되지 않고 인스턴스 간에 공유됩니다.
|
||
|
|
||
|
|
||
|
### propTypes
|
||
|
|
||
|
```javascript
|
||
|
object propTypes
|
||
|
```
|
||
|
|
||
|
`propTypes` 객체는 컴포넌트에 넘어오는 props가 올바른지 검사할 수 있게 해줍니다. `propTypes`에 대한 자세한 정보는 [재사용 가능한 컴포넌트](/react/docs/reusable-components.ko-KR.html)를 참고하세요.
|
||
|
|
||
|
|
||
|
### mixins
|
||
|
|
||
|
```javascript
|
||
|
array mixins
|
||
|
```
|
||
|
|
||
|
`mixins` 배열은 여러 컴포넌트 사이에 동작을 공유하는 믹스인을 사용할 수 있게 해줍니다. 믹스인에 대한 자세한 정보는 [재사용 가능한 컴포넌트](/react/docs/reusable-components.ko-KR.html)를 참고하세요.
|
||
|
|
||
|
|
||
|
### statics
|
||
|
|
||
|
```javascript
|
||
|
object statics
|
||
|
```
|
||
|
|
||
|
`statics` 객체는 컴포넌트 클래스의 스태틱 메소드를 정의할 수 있게 해줍니다. 에를 들어:
|
||
|
|
||
|
```javascript
|
||
|
var MyComponent = React.createClass({
|
||
|
statics: {
|
||
|
customMethod: function(foo) {
|
||
|
return foo === 'bar';
|
||
|
}
|
||
|
},
|
||
|
render: function() {
|
||
|
}
|
||
|
});
|
||
|
|
||
|
MyComponent.customMethod('bar'); // true
|
||
|
```
|
||
|
|
||
|
이 블럭 안에서 정의된 메소드는 인스턴스를 하나도 만들지 않은 시점에도 호출할 수 있고, 컴포넌트의 props나 state에 접근할 수 없습니다. 스태틱 메소드에서 props의 값을 확인하려면 호출자가 스태틱 메소드에 props를 인자로 넘기도록 해야합니다.
|
||
|
|
||
|
|
||
|
### displayName
|
||
|
|
||
|
```javascript
|
||
|
string displayName
|
||
|
```
|
||
|
|
||
|
`displayName` 문자열은 디버그 메시지에 사용됩니다. JSX는 이 값을 자동으로 설정합니다. [JSX 깊이 알기](/react/docs/jsx-in-depth.html#react-composite-components)를 참고하세요.
|
||
|
|
||
|
|
||
|
## 생명주기 메소드
|
||
|
|
||
|
컴포넌트의 생명주기에서 특정 시점마다 실행되는 메소드들입니다.
|
||
|
|
||
|
|
||
|
### 마운트 시: componentWillMount
|
||
|
|
||
|
```javascript
|
||
|
componentWillMount()
|
||
|
```
|
||
|
|
||
|
최초 렌더링이 일어나기 직전에 클라이언트 및 서버에서 한번 호출됩니다. 이 메소드 안에서 `setState`를 호출하면, `render()`에서 업데이트된 state를 확인할 수 있고 state가 변함에도 불구하고 `render()`가 한번만 실행됩니다.
|
||
|
|
||
|
|
||
|
### 마운트 시: componentDidMount
|
||
|
|
||
|
```javascript
|
||
|
componentDidMount()
|
||
|
```
|
||
|
|
||
|
최초 렌더링이 일어난 다음 클라이언트에서만 한번 호출됩니다. (서버에서는 호출되지 않습니다.) 이 시점에 컴포넌트는 `this.getDOMNode()`로 접근 가능한 DOM 표현을 가집니다.
|
||
|
|
||
|
다른 자바스크립트 프레임워크를 연동하거나, `setTimeout`/`setInterval`로 타이머를 설정하고 AJAX 요청을 보내는 등의 작업을 이 메소드에서 합니다.
|
||
|
|
||
|
> 주의:
|
||
|
>
|
||
|
> v0.9 이전까지 DOM 노드가 마지막 인자로 넘어왔습니다. 이것을 사용하고 있었다면 이제는 `this.getDOMNode()`로 DOM 노드에 접근할 수 있습니다.
|
||
|
|
||
|
|
||
|
### 업데이트 시: componentWillReceiveProps
|
||
|
|
||
|
```javascript
|
||
|
componentWillReceiveProps(object nextProps)
|
||
|
```
|
||
|
|
||
|
컴포넌트가 새로운 props를 받을 때 호출됩니다. 이 메소드는 최초 렌더링 시에는 호출되지 않습니다.
|
||
|
|
||
|
`render()`가 호출되기 전에 prop의 변화를 감지하여 `this.setState()`를 호출해서 state를 업데이트할 수 있습니다. 이전 props는 `this.props`로 접근할 수 있습니다. 이 함수 안에서 `this.setState()`를 호출해도 추가 렌더링이 발생하지 않습니다.
|
||
|
|
||
|
```javascript
|
||
|
componentWillReceiveProps: function(nextProps) {
|
||
|
this.setState({
|
||
|
likesIncreasing: nextProps.likeCount > this.props.likeCount
|
||
|
});
|
||
|
}
|
||
|
```
|
||
|
|
||
|
> 주의:
|
||
|
>
|
||
|
> `componentWillReceiveState`에 해당하는 메소드는 없습니다. prop이 변할 때 state가 바뀔 수는 있지만, 그 역은 불가능합니다. state의 변화에 따라 작업을 실행해야 하면 `componentWillUpdate`를 사용하세요.
|
||
|
|
||
|
|
||
|
### 업데이트 시: shouldComponentUpdate
|
||
|
|
||
|
```javascript
|
||
|
boolean shouldComponentUpdate(object nextProps, object nextState)
|
||
|
```
|
||
|
|
||
|
새로운 props 또는 state를 받아 렌더링을 하기 전에 호출됩니다. 최초 렌더링 시나 `forceUpdate`를 사용하는 경우에는 호출되지 않습니다.
|
||
|
|
||
|
새로운 props와 state가 컴포넌트 업데이트를 필요로 하지 않는 것이 확실하다면
|
||
|
`false`를 리턴하세요.
|
||
|
|
||
|
```javascript
|
||
|
shouldComponentUpdate: function(nextProps, nextState) {
|
||
|
return nextProps.id !== this.props.id;
|
||
|
}
|
||
|
```
|
||
|
|
||
|
`shouldComponentUpdate`가 false를 리턴하면, 다음에 state가 바뀌기 전까지 `render()`가 완전히 호출되지 않고 넘어갑니다. (그리고 `componentWillUpdate`와 `componentDidUpdate` 또한 호출되지 않습니다.)
|
||
|
|
||
|
기본적으로 `shouldComponentUpdate`는 항상 true를 리턴합니다. `state`가 제자리에서(in place) 바뀐 경우에 발생하는 파악하기 힘든 버그를 막기 위함입니다. 하지만 `state`가 항상 변경 불가능하도록 주의하고 `render()`에서 `props`와 `state`를 읽기만 하면 이전 props 및 state와 바뀌는 값을 비교하는 `shouldComponentUpdate`를 직접 구현할 수 있습니다.
|
||
|
|
||
|
성능에 병목이 있다면, 특히 컴포넌트가 매우 많은 경우 `shouldComponentUpdate`를 사용하여 앱을 빠르게 만들 수 있습니다.
|
||
|
|
||
|
|
||
|
### 업데이트 시: componentWillUpdate
|
||
|
|
||
|
```javascript
|
||
|
componentWillUpdate(object nextProps, object nextState)
|
||
|
```
|
||
|
|
||
|
새로운 props나 state를 받았을 때 렌더링 직전에 호출됩니다. 최초 렌더링 시에는 호출되지 않습니다.
|
||
|
|
||
|
업데이트가 일어나기 전에 준비하기 위해 사용할 수 있습니다.
|
||
|
|
||
|
> 주의:
|
||
|
>
|
||
|
> 이 메소드에서는 `this.setState()`를 호출할 수 없습니다. prop 변화에 반응하여 state를 업데이트해야 할 경우, `componentWillReceiveProps`를 대신 사용하세요.
|
||
|
|
||
|
|
||
|
### 업데이트 시: componentDidUpdate
|
||
|
|
||
|
```javascript
|
||
|
componentDidUpdate(object prevProps, object prevState)
|
||
|
```
|
||
|
|
||
|
컴포넌트의 업데이트가 DOM에 반영된 직후에 호출됩니다. 최초 렌더링 시에는 호출되지 않습니다.
|
||
|
|
||
|
컴포넌트가 업데이트된 뒤 DOM을 조작해야 하는 경우 사용할 수 있습니다.
|
||
|
|
||
|
> 주의:
|
||
|
>
|
||
|
> v0.9 이전까지 DOM 노드가 마지막 인자로 넘어왔습니다. 이것을 사용하고 있었다면 이제는 `this.getDOMNode()`로 DOM 노드에 접근할 수 있습니다.
|
||
|
|
||
|
|
||
|
### 마운트 해제 시: componentWillUnmount
|
||
|
|
||
|
```javascript
|
||
|
componentWillUnmount()
|
||
|
```
|
||
|
|
||
|
컴포넌트가 DOM에서 마운트 해제 되기 직전에 호출됩니다.
|
||
|
|
||
|
이 메소드에서 타이머를 무효화하거나 `componentDidMount`에서 만들어진 DOM 요소를 정리하는 등 필요한 정리 작업을 수행할 수 있습니다.
|