티스토리 뷰
React State 정의 차이점
// class fields 사용했을 경우
class Test extens Component {
state = {
number: 1
}
handleIncrease() {
this.setState({
number: this.state.number + 1
});
}
...
}
// constructor 사용했을 경우
class Test extens Component {
constructor(props) {
super(props);
this.state = {
number: 1
}
this.handleIncrease = this.handleIncrease.bind(this);
}
handleIncrease() {
this.setState({
number: this.state.number + 1
});
}
...
}
constructor 에서 super(props) 를 호출 한 이유는, 우리가 컴포넌트를 생성하며, Component 를 상속했으며, 여기에 constructor 를 작성하게 되면 기존의 클래스 생성자를 덮어쓰게 됩니다.(다시 구현을 함) 그렇기에, 리액트 컴포넌트가 지니고있던 생성자를 super 를 통하여 미리 실행하고, 그 다음에 우리가 할 작업 (state 설정) 을 해주는 것 입니다.(초기화 하는 과정이라고 생각 됨)
class fields , constructor 둘 다 사용할 경우 class fields(먼저 실행) > constructor(뒤에 실행)
constructor 사용 경우 this를 찾을 수 없게 되어 constructor 에서 state를 바인딩 시켜줘야 한다
'React & Vue' 카테고리의 다른 글
React setState시 state 데이터 사용법 (0) | 2019.01.23 |
---|---|
React setState 시 하위 객체가 존재 할 경우 (0) | 2019.01.23 |
리액트 강좌 목록 (0) | 2019.01.23 |
React Redux 설치 및 세팅 방법 (0) | 2019.01.22 |
화살표 함수 Arrow function 란 (0) | 2019.01.22 |
- Total
- Today
- Yesterday
- 스쿠터 여행
- 인터바이크
- 보성 여행
- 군산 게스트하우스
- 담양 여행
- vscode
- 영광 여행
- Docker
- 스쿠터 전국 일주
- 돌장갑
- 오라클 DB 링크
- 은파호수공원
- 송내역 룸카페
- 초원사진관
- 리니지m
- 남자 혼자 여행
- 국제반점
- 송내 카페
- 송내 룸카페
- 군산 여행
- 군산 가볼만한곳
- 남자 혼자 국내 여행
- 윈드스크린
- kendo grid
- 베스파LX
- 고흥 여행
- 송내역 카페
- 나래바이크
- 전국 일주 여행
- 제주도 스쿠터 여행
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | 5 | 6 | 7 |
8 | 9 | 10 | 11 | 12 | 13 | 14 |
15 | 16 | 17 | 18 | 19 | 20 | 21 |
22 | 23 | 24 | 25 | 26 | 27 | 28 |
29 | 30 | 31 |