inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

fetcher은 정상적으로 값을 리턴하는데 useSWR의 data에 값이 들어오지 않습니다.

311

재미있는 말미잘

작성한 질문수 6

0

1. Login.tsx

import React, { useState, useCallback, useEffect } from "react";
import * as Styled from "./style";
import { Link, Navigate } from "react-router-dom";
import axios from "axios";
import useSWR from "swr";
import fecther from "../../utils/fetcher";

function Login() {
  const { data, error, revalidate } = useSWR(
    "http://localhost:3095/api/users",
    fecther
    // {
    //   dedupingInterval: 100000,
    // }
  );

  const [info, setInfo] = useState({
    email: "",
    password: "",
  });

  const { email, password } = info;

  const onSubmit = useCallback(
    (e) => {
      e.preventDefault();

      if (!email || !password) return;

      axios
        .post(
          "http://localhost:3095/api/users/login",
          { email, password },
          {
            withCredentials: true,
          }
        )
        .then(() => {
          revalidate();
        })
        .catch(() => {
          console.log("로그인 실패");
        });
    },
    [info]
  );

  console.log(data);

  const onChange = useCallback(
    (e) => {
      const { value, name } = e.target;
      setInfo({ ...info, [name]: value });
    },
    [info]
  );

  if (data) {
    //로그인이 되어있는 경우
    return <Navigate to="/workspace/channel" />;
  }

  return (
    <Styled.LoginContainer>
      <form className="signup" onSubmit={onSubmit}>
        <header>Sleact</header>
        <label>
          <span>아이디</span>
          <input type="email" name="email" onChange={onChange}></input>
        </label>
        <label>
          <span>비밀번호</span>
          <input type="password" name="password" onChange={onChange}></input>
        </label>

        <button>로그인</button>
        <div>
          <span>아직 회원이 아니신가요?</span>
          <Link to="/signup">
            <span className="goLogin">회원가입 하러가기</span>
          </Link>
        </div>
      </form>
    </Styled.LoginContainer>
  );
}

export default Login;

 

 

 

2. fetcher

import axios from "axios";

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

export default fetcher;

 

 

3.네트워크 users 확인

 

 

커뮤니티 qna에 검색해보고 구글링을 반복해봐도 문제가 해결되지 않아 질문드립니다 ㅠㅠ

fetcher은 data를 정상적으로 리턴하는데 useSWR에는 data가 들어오지 않습니다............

 

어떤 점이 문제인지 도움을 요청해봅니다.

 

(+추가) 이것저것 시도 해보니 fetcher에 문제가 있는 것 같습니다.

then을 통해 리턴된 값이 data에 들어가지 않습니다.

하지만 then에서 res를 콘솔에 찍어보면 값이 정상적으로 출력됩니다.

정상적으로 then을 거치는 것 같은데 어떤 점이 문제일까요..

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

답변 1

1

제로초(조현영)

return 빼먹으셨습니다.

0

재미있는 말미잘

혹시 어느부분 일까요..?  

fetcher 에서는 return으로 반환해보기도 했습니다...ㅠㅠ!!!!

0

제로초(조현영)

return axios... 입니다

0

재미있는 말미잘

헉...이럴수가 정말 감사합니다!!!!!!!!!!!!! ㅠㅠㅠㅠㅠㅠㅠㅠㅠㅠㅠㅠㅠㅠㅠㅠㅠㅠㅠ

기본 셋팅과 관련하여

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