• 카테고리

    질문 & 답변
  • 세부 분야

    프론트엔드

  • 해결 여부

    해결됨

props 사용 시 중괄호 질문

23.10.06 22:56 작성 조회수 280

0

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

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

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

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

답변 2

·

답변을 작성해보세요.

1

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

우선 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 인턴

2023.10.08

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

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

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

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

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

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