inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

Slack 클론 코딩[실시간 채팅 with React]

리버스 인피니트 스크롤링(useSWRInfinite)

infiniteQuery 시 undefined 에러

1091

homie

작성한 질문수 15

0

안녕하세요, 강의는 swr로 보고 저는 제로초님 깃헙에 front-rq 레포 보면서 react-query로 진행 하고 있는데요,

강좌가 swr이라 가능하면 혼자 에러 해결하려 했는데 몇시간째 해결이 안되서 질문 남깁니다ㅜ 부탁드립니다.

에러 원인은 chatData가 undefined 여서 생기는 것 같습니다.

pages/Channel/index.tsx에서 useInfiniteQuery 요청이 안가고 chatData가  undefined로 나옵니다. 

members, channels 정보 요청은 정상적 불러오는데 useInfiniteQuery로 불로온 요청은 응답하지 않는 이유를 모르겠습니다.


강의 보면서 하다가 isLoading, isFetching 도 넣어보고, 순서도 바꿔 보고 했는데 안되서 지금은 제로초님 git hub에 fornt-rq 폴더의 코드를 복붙했는데도 Can't not read properties undifined 에러 뜨네요 ㅠ

전체 코드

https://github.com/HomieKim/sleact/blob/master/pages/Channel/index.tsx

react-query Socket.io 웹팩 typescript react babel 클론코딩

답변 1

0

제로초(조현영)

간단합니다. chatData가 undefined가 아닐 때에만 화면을 렌더링하시면 됩니다.

if (!chatData) { return null }

이런 식으로요.

0

homie

렌더링 시 에러가 일어나는게 아니라

const isEmpty = chatData?.pages[0]?.length === 0;
const isReachingEnd = isEmpty || (chatData && chatData.pages[chatData.pages.length - 1]?.length < 20) || false;

여기서 chatData가 undefined인데 접근을 하려고 해서 에러나는 것 같습니다. ㅜ

useInfiniteQuery가 실행되서 빈 배열 같은걸 받아야하는 것 같은데 network창 보면 요청이 가기도 전에 저기서 접근을 하더라구요 ㅠ

0

제로초(조현영)

chatData?.pages?.[0]?.length 로 수정하세요.

0

homie

답변 감사합니다 덕분에 해당 이슈는 해결을 했구요!

제가 잘못 한건지 모르겠는데 github의 front-rq 폴더 기준으로 useInfiniteQuery에 pageParam의 초기값이 ({pagePram}) => fetcher(~~~) 이런식으로  되어있는데 요청이 실패해서 network 탭 보니까 chats?perpage=20&page=NaN 이런식으로 가더라구요 ({pagePram=0}) => fetcher(~~~) 이런식으로 pageParam의 초기값을 0으로 지정해주니까 정상적으로 동작합니다.

그리고  channelData를 받아오는 useQuery의 query Key가 중복되는 것 같아서 수정 했습니다.
['workspace', workspace, 'channel', channel, 'chat'] => ['workspace', workspace, 'channel', channel, 'channel']

혹시 같은 에러 격는 사람이 있을까봐 남깁니다.

기본 셋팅과 관련하여

0

106

1

초기 셋팅 back과 front만 남겨두고 다 지운 후 진행 방법

0

109

2

focus 시에만 화면 업데이트 되는 이유 + 해결방법

0

165

2

useEffect 개수 관리

0

122

2

라이브러리 서치 방법

0

118

2

함수 정의 패턴

0

80

1

npm run dev 에러

0

156

3

npx webpack 후 에러

0

187

2

'void' 형식 식의 truthiness를 테스트할 수 없습니다.ts(1345)

0

153

2

사용자 가입시 에러발생 (TypeError: Cannot read properties of null (reading 'addMembers')

1

192

2

초기세팅중 packge.json 에러떠요

0

163

2

CORS - Access-Control-Allow-Origin 누락 문제

0

439

3

로그인 페이지 무한 새로고침 현상

0

608

2

Module not found: Error: Can't resolve './App' 에러

0

970

1

배포 방법

0

306

2

npm run dev 시 빌드가 매우 느려졌습니다

0

1011

2

alias 경로 설정 오류

0

462

2

fetcher 함수의 data 값이 두번 찍히는 이유

0

282

1

제네릭 질문

0

225

2

ts-node 대신 tsx 사용여부

0

379

1

배포 관련 질문

0

249

1

[nginx + https] 서비스를 실행하면 niginx가 아닌 서비스 화면을 보여주게 하고 싶습니다.

0

395

2

[배포하기] webpack에 aws 퍼블릭 IPv4 주소 와 포트 주소를 작성하고 나서 빌드후 실행하면 오류가 발생합니다.

0

341

1

users 호출 시 쿠키가 담기지 않는 이슈 질문드립니다.

0

252

2