매일 해내는 개발/React
[React] reactQuery queryKey와 queryFn의 관계, refetch()
해야지
2023. 3. 2. 23:56
반응형
useQuery를 사용하면서 알게 된 몇가지 사실들!
1. queryKey와 queryFn의 관계
const { data: activeProjectsData } = useQuery({
queryKey: ['myProjects', filteredPidList],
queryFn: getActiveProjects,
staleTime: staleTime.myProjects,
enabled: !!currentPidList,
});
=> queryKey에 있는 데이터를 queryFn이 매개변수로 사용할 수 있다.
queryFn에 정의해준 함수에서 매개변수를 콘솔로 찍어보면 아래와 같이 객체가 찍히는 것을 알 수 있다.
이 객체 중 하나로 queryKey가 들어가기 때문에 이를 활용해서 함수 안에서 자유롭게 사용할 수 있다.
2. queryFn에 매개변수 지정하기
하지만 난 다른 컴포넌트에서 invalidateQueries를 써야해서 queryKey 안에 지역 변수를 사용할 수 없다면
const { data: activeProjectsData } = useQuery({
queryKey: ['myProjects', "filteredPidList"],
queryFn: ()=>getActiveProjects(filteredPidList),
staleTime: staleTime.myProjects,
enabled: !!currentPidList,
});
이와 같이 함수에 직접 매개변수를 지정할 수 있고 아까와 같이 함수에서 매개변수를 찍어보면
아래와 같이 값들이 들어오는 것을 확인할 수 있다.
하지만 이렇게 했을 때 데이터가 fetch 되지 않는 오류가 발생한다.
이럴 땐 useQuery의 기본 option 중 하나인 refetch를 통해 수동으로 다시 쿼리를 가져올 수 있다.
적절한 곳에서 refetch()함수를 호출해주면 데이터가 다시 불러와지는 것을 react query devtools를 통해 확인할 수 있었다.
하지만 서버에 부하를 줄 수 있기 때문에 페이지 성능에는 좋지 않을 것 같다는 생각이 든다.
반응형