inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

한 입 크기로 잘라먹는 React.js 실전 프로젝트 - SNS 편

(3.6) 투두리스트 UI 구현하기

props 질문

해결된 질문

46

gmldnjs0402

작성한 질문수 32

0

TodoItem 에서 todo값을 props로 넘겨줄때 왜 {...todo} 로 사용하나요? {todo} 는 안되는건가요?

react typescript react-query supabase zustand

답변 2

0

이정환 Winterlood

안녕하세요 gmldnjs0402님 이정환입니다.

아래에 AI 인턴이 적절한 설명을 해 주었네요! 확인해보시고 어려운 부분이 있으시면 추가 질문 부탁드립니다.

참고로 이번 질문에서 다루고 있는 내용은 React의 컴포넌트 구조와 훅 사용 패턴에 관한 React.js 기초 개념에 해당합니다. 이 부분은 제 강의 「한입 리액트」에서 다루고 있는 주제이기도 합니다. 아래 링크에 해당 내용을 정리해 둔 자료가 있으니 함께 참고해 보셔도 도움이 될 것 같습니다.

https://reactjs.winterlood.com/c89cba30-39b6-4094-85f6-f87a16842028

읽어보시고 추가로 궁금한 점이 생기면 언제든지 질문 주세요 🙂

0

인프런 AI 인턴

안녕하세요, 인프런 AI 인턴입니다. gmldnjs0402님.

React에서 props를 전달할 때 {...todo}를 사용하면 todo 객체의 모든 속성을 각각의 개별적인 props로 전달할 수 있습니다. 즉, 각 속성이 직접 props로 넘어가게 되어, 각각의 요소들을 보다 명확하게 사용할 수 있습니다.

반면에 {todo}를 사용할 경우, todo 객체 자체가 하나의 단일 prop으로 전달됩니다. 이렇게 하면, 자식 컴포넌트 내부에서 접근할 때 props.todo.id, props.todo.name와 같은 방식으로 접근해야 합니다.

차이점 요약:

  1. {…todo} 방식

    • 개별 속성들로 분리하여 전달되므로, 자식 컴포넌트에서 id, name과 같은 속성에 곧바로 접근할 수 있습니다.
    • 코드가 간결하며, 때로는 가독성이 좋아집니다.
  2. {todo} 방식

    • todo 객체 전체가 단일 prop으로 전달되며, 내부 속성에 접근하려면 이를 별도로 구조분해해야 합니다.
    • 구조가 잘 정의된 객체를 통째로 넘길 때 유리할 수 있습니다.

이 때문에, 어떤 방법을 사용할지는 주로 코드를 작성하는 사람의 스타일이나, 컴포넌트의 구조와 사용 용도에 따라 달라집니다.

이와 관련된 유사한 질문과 답변은 다음 링크에서 확인할 수 있습니다:
- 질문 제목: [리액트] props로 객체 전달 시 key prop 문제 및 해결법

저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다. 현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏 추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.

회원가입 구현 (구현 후 최종 화면 출력 X)

0

39

2

(6.11) 회원가입시 프로필 정보 자동 생성하기 Q. 호출 순서 문의

0

36

1

명시적 타입 선언(콜론 타입 선언)과 as 타입 단언 차이

0

37

2

useMutation 적용 후 새로운 글 등록시 content가 안보여요

0

48

2

6.8 zustand 세션 질문입니다.

0

92

2

next.js 강의에서도 리액트 라이브러리들을 다뤄주시나요?

0

79

2

shadcn에서 radix ui와 base ui 차이는 뭔가요?

1

319

2

updateTodo 함수 생성시 화살표 함수 사용 안하는 이유

0

75

2

4.11 바로 투두 삭제가 안됨 질문

0

85

3

매개변수 updatedTodo 관련 질문

0

66

3

인증 정보가 만료되었을 때 라우트 가드 처리가 궁금합니다!

0

78

2

supabase를 사용하지 않을 경우 세션 데이터의 변경을 감지하고 스토어에 보관하는 방법이 궁금합니다!

0

69

2

4.6 id를 string으로 변경시 오류

0

64

2

리액트 타입스크립트 관련 질문있습니다.

0

62

1

소셜 로그인 구현하기 관련하여 질문이 있습니다!

0

98

2

ui 파일 질문드립니다.

0

76

1

tanstack query devtools에서 질문있습니다!

0

66

2

댓글 삭제 시 isPending 질문

0

64

2

두번째 예외상황에 대해 질문있습니다!

0

65

1

리액트 쿼리 질문입니다

1

72

2

개발자도구에서 components 가 안보입니다.

0

94

3

state 관리에 대한 정리

0

79

3

[(2.4) Shadcn/ui를 소개합니다] 강의 Shadcn 세팅 관련 질문 있습니다.

0

176

3

like 테이블에서 왜 create_at이 필요한지 궁금합니다.

0

78

1