useCallback은 특정 함수를 렌더링할 때마다 새로 만들지 않고, 재사용하기 위해 사용하는 Hook이다.
아래 코드에는 useCallback이 사용된 change와 insert라는 함수가 있다.
change는 의존성 배열이 빈 배열이고, insert는 의존성배열에 string과 stringList가 들어가 있다.
const change = useCallback((e) => {
setString(e.target.value);
}, []);
const insert = useCallback((e) => {
const newList = stringList.slice();
newList.push(string);
setStringList(newList);
}, [string, stringList]);
둘의 차이가 무엇이길래, 하나는 의존성 배열이 비어있고, 하나는 값이 포함되어 있을까?
change는 두번째 인자에 빈 배열을 주었기 때문에, 최초 렌더링 시에만 함수가 생성되고 이후에는 생성되지 않는다.
insert는 string과 stringList가 변경될 때만 함수를 재생성한다.
즉, insert의 경우 string과 stringList가 변하면 함수도 재생성되어야 한다. 즉, 두 state에 의존적이다.
하지만, change는 state를 사용하지 않고, 단지 state를 변경하는 것이므로, state에 의존적이지 않다.
state가 변함에 따라 change 함수를 재생성해줄 필요는 없는 것이다.
정리하자면, 해당 함수에서 state를 사용한다면, 말그대로 state에 의존하는 함수이므로 두번째 인자의 배열 안에 state를 추가해줘야 하고,
state에 의존적이지 않은 함수라면 빈 배열로 넣어주면 된다.
'TIL_개발일기' 카테고리의 다른 글
[TIL] antd form에서 input reset하는 법 (0) | 2021.04.21 |
---|---|
[TIL_개발일기_210414] [css] active와 focus의 차이 (0) | 2021.04.15 |
[TIL_개발일기_210413] a 클릭 영역 늘리기 / next에서 router.push()와 Link의 차이 (0) | 2021.04.13 |
[TIL_개발일기_210405] axios.defaults.baseurl / findOne (0) | 2021.04.06 |
[TIL_개발일기_210326] table width 고정, 자동 줄바꿈 (0) | 2021.03.26 |