inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

SWR 사용 시 에러가 발생하여 데이터가 전달되지 않습니다.

258

Sangmin Park

작성한 질문수 7

0

안녕하세요. 강의에서 배운 SWR을 토대로 프로젝트를 진행중에 궁금한 점이 생겨 질문드립니다.

1. DetailTerm.tsx

import React from 'react'
import useSWR from 'swr'
import fetcher from 'utils/fetcher'

const DetailTerm = () => {
  const { data } = useSWR(
    'https://jsonplaceholder.typicode.com/users/1',
    fetcher,
  )

  if (data === undefined) return <div>No Data!</div>

  return (
    <ul>
      {data.map((term) => (
        <li key={term.id}>
          {term.name} ({term.description})
        </li>
      ))}
    </ul>
  )
}

export default DetailTerm

2. fetcher.ts

import axios from 'axios'

const fetcher = (url: string) => {
  axios
    .get(url, {
      withCredentials: true,
    })
    .then((response) => response.data)
}

// `${process.env.NEXT_PUBLIC_API_URL}/url/`

export default fetcher

이와 같이 코드를 작성하였으나 data.map에서

Property 'map' does not exist on type 'void'.ts(2339)

에러가 발생하였고, No Data!가 떠 결국 data에 response.data가 저장되지 않고 있다는 사실을 알게 되었습니다.

이에 useSWR에 타입을 부여하여 해결할 수 있다는 사실을 구글링을 통해 알게되었고, useSWR<string[]>~ 와 같이 제너릭을 넣어서 작성했더니

URL에 위와 같은 에러 밑줄이 발생하였고 여전히 No Data!가 리턴되고 있습니다.

해결책이 뭔지 궁금합니다.ㅜㅜ

아 그리고, 선생님의 슬리액 깃허브를 확인해봤는데 SWR 대신 React-Query를 적용하신 프로젝트 파일도 있더라구요. 혹시 리액트 쿼리로는 따로 강의 진행 계획은 없으신건지도 궁금합니다.

감사합니다.

 

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

답변 1

1

제로초(조현영)

fetcher에서 return 빠뜨리셨습니다. react-query는 소스코드만 제공합니다.

0

Sangmin Park

감사합니다!

기본 셋팅과 관련하여

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

151

2

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

1

192

2

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

0

162

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

1010

2

alias 경로 설정 오류

0

461

2

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

0

282

1

제네릭 질문

0

225

2

ts-node 대신 tsx 사용여부

0

377

1

배포 관련 질문

0

249

1

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

0

395

2

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

0

341

1

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

0

252

2