인프런 영문 브랜드 로고
인프런 영문 브랜드 로고

인프런 커뮤니티 질문&답변

inflearn_su님의 프로필 이미지
inflearn_su

작성한 질문수

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

props 사용 시 중괄호 질문

해결된 질문

작성

·

415

0

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

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

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

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

답변 2

1

이정환 Winterlood님의 프로필 이미지
이정환 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 인턴이에요.

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

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

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

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

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

inflearn_su님의 프로필 이미지
inflearn_su

작성한 질문수

질문하기