inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

한 입 크기로 잘라 먹는 리액트(React.js) : 기초부터 실전까지

8.6) Update - 투두 수정하기

TodoList에서 checkBox 업데이트를 위한 onUpdate의 props전달?

175

ju004100

작성한 질문수 7

1

TodoList에서 checkBox 업데이트를 위한 onUpdate의 props전달?에 대해서 질문이 있습니다

 

첫 번째, 부모 컴포넌트에서 자식 컴포넌트로 값(변수, 리스트, 함수 등)을 전달하는 것이 props인건지 햇갈립니다

 

두 번째, onUpdate의 구동방식은 이해되었습니다. 다만 app.jsx가 아니라 List.jsx에서 만들어도 되지 않나? 라는 의문점이 있습니다. 리렌더링 때문일까요? 아님 다른 이유가 있는건지 궁금합니다.

javascript react node.js

답변 2

0

이정환 Winterlood

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

우선 5.4) Props로 데이터 전달하기 챕터에서 말씀드린 것 처럼 React에서 컴포넌트간의 데이터를 주고 받는 방법은 모두 Props를 통해 이루어집니다. 그리고 이 Props는 반드시 부모 -> 자식 방향으로만 전달할 수 있습니다. 따라서 부모 컴포넌트에서 자식 컴포넌트로 어떤 값을 전달했든 값을 전달했다면 모두 Props라고 볼 수 있습니다.

onUpdate를 List 컴포넌트에서 정의할 수 없는 이유는 onUpdate 함수 내부에서 App 컴포넌트의 todos State와 setTodos 함수를 사용해야 하기 때문입니다. 따라서 todos State와 setTodos 함수가 정의된 App 컴포넌트에 이 함수를 선언해야 합니다.

0

인프런 AI 인턴

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

질문해주신 내용과 관련하여 props와 onUpdate 함수에 대한 이해를 도와드리겠습니다.

  1. Props의 의미:

    • React에서는 상위 컴포넌트가 하위 컴포넌트에게 정보를 전달하기 위해 props를 사용합니다. props는 일종의 매개체 역할을 하며, 값(변수), 함수, 객체 등 다양한 데이터를 전달할 수 있습니다. 이는 부모 컴포넌트가 자식 컴포넌트에게 데이터를 내려주는 방식이며, 자식 컴포넌트는 이러한 props를 통해 전달받은 데이터를 가진 채로 렌더링을 수행합니다.
  2. onUpdate 함수를 App.jsx가 아닌 List.jsx에서 만들어도 되는가에 대한 의문:

    • onUpdate와 같은 이벤트 핸들링 함수는 상태 관리가 필요한 경우, 보통 상태가 존재하는 위치(상위 컴포넌트)에서 선언합니다. 이 방식은 최적화와 상태 관리의 용이성 측면에서 유리합니다.
    • 만약 onUpdate 함수를 List.jsx에서 정의할 경우, 상태관리의 일관성이 깨질 수 있으며, 상위 컴포넌트인 App.jsx에서의 상태 변경에 따른 리렌더링이 제대로 이루어지지 않을 수 있습니다.
    • 일반적으로 상위 컴포넌트에서 선언하여 하위 컴포넌트에 전달하는 이유는 상태와 그에 따른 로직이 일관되게 유지되도록 하기 위함입니다.

다음 링크들은 유사한 내용에 대해 논의된 질문들로서 추가적으로 참조하시면 도움이 될 것입니다:

  1. Props 접근 방식 질문
    여기에서는 props에 대한 구조 분해 할당 방식과 일반적인 접근 방식의 차이에 대해 다루고 있습니다.

  2. onDelete관련
    이 게시물에서는 props로 함수 전달 시의 역할에 대한 설명이 포함되어 있습니다.

위 내용을 참고하시어, onUpdate와 props에 대한 이해를 조금 더 깊게 하시길 바랍니다.

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

useEffect와 lifecycle문의

0

26

2

프론트엔드 학습 수준 문의

0

38

2

리액트 챕터별 코드에서 eslint 설정파일이 없어요

0

48

2

데이터 로딩중 화면만 계속 나와요!!

0

55

2

퍼블리셔일경우 어느정도 수준까지 강의를 들어야할까요

0

79

2

이후의 커리큘럼 문의

0

102

2

실슬환경 설정에서 save후 console.log 부분이 새로고침이 안되는현상입니다.

0

50

2

최적화 관련 질문있습니다 (useMemo 등)

0

84

3

프로바이더 컴포넌트의 위치는 어떤 기준인가요?

1

82

3

Date 객체에 관련하여 질문드립니다.

0

85

2

리액트 개정판 교재 질문

0

60

2

예제코드가 안나와요!

0

78

2

select a variant 선택에서 javascript와 javascript+react compiler 중 무엇을 선택해야하나요? com

0

108

2

onMouseEnter 관련 문의 드립니다

0

92

3

배열의 렌더링 관련 질문 드립니다.

0

73

2

2:40초 refObj를 콘솔로 출력시 오류가 발생합니다.

0

113

2

TS, 리액트 강의중에 뭘 먼저 수강하는게 좋을까요?

0

136

2

useCallback 적용한 onCreate, onUpdate, onDelete 함수..

0

69

1

vs code 자동완성관련 문의

0

113

2

91강 useEffect내에서 상태변화함수 호출시 발생하는 에러

1

178

2

87강 필터 함수 질문

0

69

2

useRef, useState count 비교

0

67

2

안된다고했던 이유가 무엇이었는지 모르겠습니다

0

90

2

85강에서 객체를 왜 클래스로 만들어서 new 하지 않는건지 궁금합니다.

0

75

2