props 사용 시 중괄호 질문
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로 전달받을 값을 변수로 사용하거나 함수를 전달받을 때 사용됩니다.
더 궁금한 점이 있으시면 언제든지 물어보세요. 감사합니다.
useEffect와 lifecycle문의
0
36
2
프론트엔드 학습 수준 문의
0
48
2
리액트 챕터별 코드에서 eslint 설정파일이 없어요
0
53
2
데이터 로딩중 화면만 계속 나와요!!
0
57
2
퍼블리셔일경우 어느정도 수준까지 강의를 들어야할까요
0
84
2
이후의 커리큘럼 문의
0
104
2
실슬환경 설정에서 save후 console.log 부분이 새로고침이 안되는현상입니다.
0
53
2
최적화 관련 질문있습니다 (useMemo 등)
0
86
3
프로바이더 컴포넌트의 위치는 어떤 기준인가요?
1
82
3
Date 객체에 관련하여 질문드립니다.
0
87
2
리액트 개정판 교재 질문
0
60
2
예제코드가 안나와요!
0
78
2
select a variant 선택에서 javascript와 javascript+react compiler 중 무엇을 선택해야하나요? com
0
110
2
onMouseEnter 관련 문의 드립니다
0
93
3
배열의 렌더링 관련 질문 드립니다.
0
73
2
2:40초 refObj를 콘솔로 출력시 오류가 발생합니다.
0
114
2
TS, 리액트 강의중에 뭘 먼저 수강하는게 좋을까요?
0
138
2
useCallback 적용한 onCreate, onUpdate, onDelete 함수..
0
71
1
vs code 자동완성관련 문의
0
119
2
91강 useEffect내에서 상태변화함수 호출시 발생하는 에러
1
186
2
87강 필터 함수 질문
0
71
2
useRef, useState count 비교
0
67
2
안된다고했던 이유가 무엇이었는지 모르겠습니다
0
92
2
85강에서 객체를 왜 클래스로 만들어서 new 하지 않는건지 궁금합니다.
0
77
2





