해결된 질문
작성
·
415
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 인턴이에요.
props를 사용할 때 중괄호는 해당 값을 변수로 전달받을 때 사용합니다.
예를 들어, const DiaryEditor = ({onCreate}) => {return}의 경우, DiaryEditor 컴포넌트에서 onCreate라는 props를 전달받고 그 값을 변수로 사용하고자 할 때 중괄호를 사용합니다.
함수를 전달받을 때는 함수를 전달받는 props에 중괄호를 사용합니다. 이렇게 하면 해당 함수를 변수로 전달받을 수 있게 됩니다.
따라서, 중괄호는 props로 전달받을 값을 변수로 사용하거나 함수를 전달받을 때 사용됩니다.
더 궁금한 점이 있으시면 언제든지 물어보세요. 감사합니다.