inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

props 사용 시 중괄호 질문

해결된 질문

484

inflearn_su

작성한 질문수 1

0

props를 사용해 전달 받을 때 어떤 상황에서 중괄호를 사용하고 특히 함수를 전달 받을 때 왜 중괄호가 필요한지 궁금합니다.

const DiaryEditor = ({onCreate}) => {return}

const DiaryList = ({diaryList}) => {return}

const DiaryItem = ({author, content, create_date, emotion, id}) => {return}

javascript react node.js

답변 2

1

이정환 Winterlood

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

우선 Props란 부모 컴포넌트가 자식 컴포넌트에게 보내준 값 입니다.
그리고 이 값들은 객체로 묶여 자식 컴포넌트에게 전달됩니다.

예를 들어 아래 코드에서처럼 부모 컴포넌트에서 자식 컴포넌트에게 a는 1, b는 2 라는 값을 전달하면

function Parent(){
  return <Child a={1} b={2} />
  // 자식 컴포넌트에게 2개의 Props 전달 (a:1, b:2)
}

이렇게 전달된 값들은 객체로 묶여 자식 컴포넌트에게 전달됩니다.
그리고 이 객체를 리액트에서는 흔히 관례상 props 라고 부릅니다.
따라서 아래 코드에서처럼 자식 컴포넌트에서 부모 컴포넌트로부터 받은 props를 콘솔에 출력하면 다음과 같은 결과가 나타납니다.

function Child(props){
  console.log(props)
  // { a:1, b:2 }

  return <>...</>
}

따라서 이렇게 객체로 묶인 Props의 값을 바로 꺼내 사용하기 위해 보통 다음과 같이 구조 분해 할당을 이용하게 됩니다.

 function Child({a, b}){
  console.log(a, b)
  // 1 2

  return <>...</>
}

0

인프런 AI 인턴

안녕하세요, 인프런 AI 인턴이에요.

props를 사용할 때 중괄호는 해당 값을 변수로 전달받을 때 사용합니다.

예를 들어, const DiaryEditor = ({onCreate}) => {return}의 경우, DiaryEditor 컴포넌트에서 onCreate라는 props를 전달받고 그 값을 변수로 사용하고자 할 때 중괄호를 사용합니다.

함수를 전달받을 때는 함수를 전달받는 props에 중괄호를 사용합니다. 이렇게 하면 해당 함수를 변수로 전달받을 수 있게 됩니다.

따라서, 중괄호는 props로 전달받을 값을 변수로 사용하거나 함수를 전달받을 때 사용됩니다.

더 궁금한 점이 있으시면 언제든지 물어보세요. 감사합니다.

존재하지 않는 일기 url입력 시 alert이 두 번 떠요

0

41

1

교재(3쇄)와 강의 내용 문의

0

37

2

12.13) 하단 여백 스타일링 관련 질문 드립니다.

0

68

2

에러 질문드립니다

0

65

2

VSCode 설정 문의

0

75

2

PPT 코드 관련 질문

0

50

2

useEffect와 lifecycle문의

0

68

2

프론트엔드 학습 수준 문의

0

83

2

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

0

76

2

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

0

74

2

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

0

106

2

이후의 커리큘럼 문의

0

127

2

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

0

74

2

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

0

105

3

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

1

98

3

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

0

98

2

리액트 개정판 교재 질문

0

77

2

예제코드가 안나와요!

0

87

2

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

0

132

2

onMouseEnter 관련 문의 드립니다

0

112

3

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

0

87

2

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

0

138

2

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

0

156

2

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

0

76

1