상식닷컴
로그인
가입하기
2026년 상식닷컴 선정 식당 & 카페 리스트
2025년 2026년 신상 호텔 리스트
최근에 오픈한 호텔을 찾는다면 살펴보세요
일주일 식단표 어플
자동 일주일 식단표 어플
안드로이드
아이폰
주식 & 코인 차트의 신
1000만원으로 2000만원 만들기 프로젝트
수정하기 - React에서 리스트를 렌더링하는 방법은 무엇인가요?
닉네임
비밀번호
제목
내용
[이미지 업로드는 권한이 있는 사람만 가능. 하단 카톡으로 연락]
React에서 리스트를 렌더링하는 것은 매우 일반적인 작업이며, 이를 통해 동적인 데이터를 효과적으로 표시할 수 있습니다. 리스트를 렌더링하는 방법에 대해 자세히 알아보겠습니다. 1. 기본적인 리스트 렌더링 React에서 리스트를 렌더링하기 위해서는 주로 `map()` 함수를 사용합니다. `map()` 함수는 배열의 각 요소를 변환하여 새로운 배열을 생성하는 메서드입니다. 다음은 기본적인 리스트 렌더링의 예입니다. ```jsx import React from 'react'; const ItemList = () => { const items = ['Apple', 'Banana', 'Cherry']; return ( <ul> {items.map((item, index) => ( <li key={index}>{item}</li> ))} </ul> ); }; export default ItemList; ``` 위의 예제에서 `items` 배열을 `map()`을 사용하여 각 요소를 `<li>` 태그로 변환하고 있습니다. 각 요소에 `key` 속성을 부여하는 것이 중요한데, 이는 React가 리스트의 각 항목을 식별하고 효율적으로 업데이트할 수 있도록 도와줍니다. `key`는 배열의 각 요소가 고유해야 하며, 일반적으로 데이터의 고유한 ID를 사용하는 것이 좋습니다. 2. 고유한 키 사용하기 리스트의 각 항목에 대해 `key`를 설정할 때, 인덱스 대신 고유한 값을 사용하는 것이 좋습니다. 예를 들어, 다음과 같이 객체 배열을 사용할 수 있습니다. ```jsx import React from 'react'; const ItemList = () => { const items = [ { id: 1, name: 'Apple' }, { id: 2, name: 'Banana' }, { id: 3, name: 'Cherry' }, ]; return ( <ul> {items.map(item => ( <li key={item.id}>{item.name}</li> ))} </ul> ); }; export default ItemList; ``` 이 경우 각 항목은 고유한 `id`를 가지고 있으며, 이를 `key`로 사용하여 React가 리스트를 더 효율적으로 관리할 수 있도록 합니다. 3. 조건부 렌더링 리스트를 렌더링할 때 조건부 렌더링을 사용할 수도 있습니다. 예를 들어, 특정 조건에 따라 리스트의 일부 항목만 표시할 수 있습니다. ```jsx import React from 'react'; const ItemList = () => { const items = ['Apple', 'Banana', 'Cherry']; const showBanana = true; return ( <ul> {items.map((item, index) => { if (item === 'Banana' && !showBanana) { return null; // Banana를 표시하지 않음 } return <li key={index}>{item}</li>; })} </ul> ); }; export default ItemList; ``` 위의 예제에서는 `showBanana` 변수가 `false`일 경우 'Banana' 항목은 렌더링되지 않습니다. 4. 리스트의 상태 관리 리스트의 상태를 관리하는 것도 중요합니다. 예를 들어, 사용자가 리스트 항목을 추가하거나 삭제할 수 있는 경우, 상태를 관리해야 합니다. ```jsx import React, { useState } from 'react'; const ItemList = () => { const [items, setItems] = useState(['Apple', 'Banana', 'Cherry']); const [newItem, setNewItem] = useState(''); const addItem = () => { if (newItem) { setItems([...items, newItem]); setNewItem(''); } }; return ( <div> <input type="text" value={newItem} onChange={(e) => setNewItem(e.target.value)} /> <button onClick={addItem}>Add Item</button> <ul> {items.map((item, index) => ( <li key={index}>{item}</li> ))} </ul> </div> ); }; export default ItemList; ``` 위의 예제에서는 사용자가 입력한 값을 리스트에 추가할 수 있는 기능을 구현했습니다. `useState` 훅을 사용하여 리스트와 입력값의 상태를 관리하고 있습니다. 5. 리스트 항목 삭제 리스트에서 항목을 삭제하는 기능도 자주 필요합니다. 다음은 항목을 삭제하는 방법의 예입니다. ```jsx import React, { useState } from 'react'; const ItemList = () => { const [items, setItems] = useState(['Apple', 'Banana', 'Cherry']); const deleteItem = (index) => { const newItems = items.filter((_, i) => i !== index); setItems(newItems); }; return ( <ul> {items.map((item, index) => ( <li key={index}> {item} <button onClick={() => deleteItem(index)}>Delete</button> </li> ))} </ul> ); }; export default ItemList; ``` 이 예제에서는 각 항목 옆에 삭제 버튼을 추가하여 사용자가 항목을 삭제할 수 있도록 했습니다. `filter()` 메서드를 사용하여 선택한 항목을 제외한 새로운 배열을 생성하고 상태를 업데이트합니다. 결론 React에서 리스트를 렌더링하는 방법은 다양하며, `map()` 함수를 사용하여 배열의 요소를 JSX로 변환하는 것이 일반적입니다. 고유한 `key`를 설정하고, 조건부 렌더링, 상태 관리, 항목 추가 및 삭제 기능을 구현하는 방법을 통해 동적인 리스트를 효과적으로 관리할 수 있습니다. 이러한 기법들을 조합하여 복잡한 UI를 구성할 수 있습니다.
이용안내
커뮤니티 이용안내
×
- 게시한 게시글로 발생하는 문제는 게시자에게 책임이 있습니다.
- 게시글이 타인/타업체의 저작권을 침해할 경우 모든 책임은 게시자에게 있습니다. 게시자가 모든 손해를 부담해야 합니다.
- 상식닷컴 운영자는 게시자와 상의하지 않고 게시글을 수정 또는 삭제할 수 있습니다.
- 상식닷컴 운영자는 깨끗한 커뮤니티 공간을 만드는 것이 1순위입니다.
수정하기
취소하기