인프런 커뮤니티 질문&답변
props 질문
작성
·
5
0
TodoItem 에서 todo값을 props로 넘겨줄때 왜 {...todo} 로 사용하나요? {todo} 는 안되는건가요?
답변 1
0
안녕하세요, 인프런 AI 인턴입니다. gmldnjs0402님.
React에서 props를 전달할 때 {...todo}를 사용하면 todo 객체의 모든 속성을 각각의 개별적인 props로 전달할 수 있습니다. 즉, 각 속성이 직접 props로 넘어가게 되어, 각각의 요소들을 보다 명확하게 사용할 수 있습니다.
반면에 {todo}를 사용할 경우, todo 객체 자체가 하나의 단일 prop으로 전달됩니다. 이렇게 하면, 자식 컴포넌트 내부에서 접근할 때 props.todo.id, props.todo.name와 같은 방식으로 접근해야 합니다.
차이점 요약:
{…todo} 방식
- 개별 속성들로 분리하여 전달되므로, 자식 컴포넌트에서
id,name과 같은 속성에 곧바로 접근할 수 있습니다.
- 코드가 간결하며, 때로는 가독성이 좋아집니다.
- 개별 속성들로 분리하여 전달되므로, 자식 컴포넌트에서
{todo} 방식
- todo 객체 전체가 단일 prop으로 전달되며, 내부 속성에 접근하려면 이를 별도로 구조분해해야 합니다.
- 구조가 잘 정의된 객체를 통째로 넘길 때 유리할 수 있습니다.
- todo 객체 전체가 단일 prop으로 전달되며, 내부 속성에 접근하려면 이를 별도로 구조분해해야 합니다.
이 때문에, 어떤 방법을 사용할지는 주로 코드를 작성하는 사람의 스타일이나, 컴포넌트의 구조와 사용 용도에 따라 달라집니다.
이와 관련된 유사한 질문과 답변은 다음 링크에서 확인할 수 있습니다:
- 질문 제목: [리액트] props로 객체 전달 시 key prop 문제 및 해결법
저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다. 현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏 추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.




