map 함수를 활용하여 여러개의 컴포넌트를 렌더링할 수 있다.
const numbers = [1, 2, 3, 4, 5];
const listItems = numbers.map((number) =>
<li>{number}</li>
);
<ul>
엘리먼트 안에 포함하고 DOM에 렌더링한다.ReactDOM.render(
<ul>{listItems}</ul>,
document.getElementById('root')
);
이와 같은 방식으로 numbers 배열을 받아서 순서없는 엘리먼트 리스트를 출력하는 컴포넌트를 만들 수 있다.
function NumberList(props) {
const numbers = props.numbers;
const listItems = numbers.map((number) =>
<li>{number}</li>
);
return (
<ul>{listItems}</ul>
);
}
const numbers = [1, 2, 3, 4, 5];
ReactDOM.render(
<NumberList numbers={numbers} />,
document.getElementById('root')
);
위 코드를 실행하면 리스트의 각 항복에 key
를 넣어야 한다는 경고가 표시된다.
key에 index를 사용하는 것은 권장하지 않는다!
- 향목의 순서가 바뀌거나 항목이 하나 없어져서 index가 바뀔 경우 성능이 저하되거나 컴포넌트의 state와 관련된 문제가 발생할 수 있다.
- 인덱스를 key로 사용할 경우 부정적인 영향에 대한 설명
- 리스트 항목에 명시적으로 key를 지정하지 않으면 React는 기본으로 인덱스를 key로 사용
<li>
엘리먼트가 아니라 배열의 <ListItem />
엘리멘트 key를 가져야 한다.function ListItem(props) {
// 맞습니다! 여기에는 key를 지정할 필요가 없습니다.
return <li>{props.value}</li>;
}
function NumberList(props) {
const numbers = props.numbers;
const listItems = numbers.map((number) =>
// 맞습니다! 배열 안에 key를 지정해야 합니다.
<ListItem key={number.toString()} value={number} />
);
return (
<ul>
{listItems}
</ul>
);
}
const numbers = [1, 2, 3, 4, 5];
ReactDOM.render(
<NumberList numbers={numbers} />,
document.getElementById('root')
);