React의 목록과 키
React를 처음 사용하는 경우 키가 무엇이고 무엇을 하는지 궁금할 수 있습니다.
키와 목록에 익숙하다면 맨 아래로 건너뛰어 React에서 자동으로 키를 할당하는 방법을 배울 수 있습니다.
React의 목록 및 키 소개.
렌더링하려는 다음 데이터 목록이 있다고 가정합니다.
const someData = ['Chipata', 'Kasama', 'Mongu',
'Livingstone', 'Mansa', 'Kabwe',
'Ndola', 'Lusaka', 'Solwezi'];
JSX에서 이를 렌더링하기 위해 중괄호를 사용하고 JavaScript
map()
메서드를 사용하여 배열을 반복하고 변환합니다.const cities = someData.map(city => (
<li>{city}</li>
));
map()
콜백 함수는 원래 배열의 각 요소를 렌더링할 수 있는 구성 요소로 변환합니다. map()
의 결과는 React 구성 요소(또는 이 경우 HTML 요소)의 배열입니다.그런 다음 다음과 같이
cities
요소 내부에 <ul>
배열을 렌더링할 수 있습니다.<ul>{cities}</ul>
그러나 이 코드를 실행하면 목록 항목에 대해 키를 증명해야 한다는 경고가 콘솔에 표시됩니다.
키는 React가 추가, 업데이트 또는 제거된 구성 요소를 식별하는 데 도움이 됩니다. 구성 요소/요소에 대한 식별 역할을 합니다. why you should provide keys for list items에 대해 자세히 알아볼 수 있습니다.
React에서 키 사용
키는 고유해야 합니다. 위의
cities
배열을 올바르게 매핑하는 간단한 방법은 배열 인덱스를 키로 사용하는 것입니다.const cities = someData.map((city, i) => (
<li key={i}>{city}</li>
));
예를 들어
users
와 같은 객체 배열로 작업하는 경우. 데이터의 식별자를 키로 사용할 수 있습니다.const users = someData.map((user) => (
<li key={user.id}>{user.full_name}</li>
));
인덱스를 사용하지 마십시오
항목의 순서가 변경될 수 있는 경우 키에 인덱스를 사용하지 않는 것이 좋습니다. 이는 성능에 부정적인 영향을 미치고 구성 요소 상태에 문제를 일으킬 수 있습니다. 이유에 대해 자세히 알아보기Indexes as Keys is an Anti-pattern
키 자동 할당
렌더링된 항목에 대한 안정적인 ID가 없는 경우 내장 메서드를 사용하여 React가 이를 처리하도록 할 수 있습니다.
const cities = React.Children.toArray(
someData.map((city) => <li>{city}</li>)
);
저와 함께 배워 주셔서 감사합니다. 즐거운 코딩하세요.
저는 React에서 원격으로 일대일 교육을 제공하고 있습니다. 관심 있는? Apply here
Reference
이 문제에 관하여(React의 목록과 키), 우리는 이곳에서 더 많은 자료를 발견하고 링크를 클릭하여 보았다 https://dev.to/daryllukas/lists-and-keys-in-react-115o텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
우수한 개발자 콘텐츠 발견에 전념 (Collection and Share based on the CC Protocol.)