inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

프론트엔드 세팅하기

강사님 이 강의 좀 어려운점들이 있어요

293

terecal

작성한 질문수 162

0

존경하는 조현영 강사님 이 강의 좀 어려운점들이 있어
일단  다운 받은 소스랑 강의 진도랑 달라서 좀 헷갈려요 예를 들면 회원 가입 페이지의 submit 에 로그를 찍으시는데 이미 다 되어 있어서 주석 처리를 하고 로그를 찍었어요 이렇게 하는게 맞는걸까라는 불안감이 ㅋㅋ;

  const onSubmit = useCallback(
    (e) => {
      e.preventDefault();
      console.log(email, nickname, password, passwordCheck);
      // if (!nickname || !nickname.trim()) {
      //   return;
      // }
      // if (!mismatchError) {
      //   setSignUpError(false);
      //   setSignUpSuccess(false);
      //   axios
      //     .post('/api/users', { email, nickname, password })
      //     .then(() => {
      //       setSignUpSuccess(true);
      //     })
      //     .catch((error) => {
      //       setSignUpError(error.response?.data?.statusCode === 403);
      //     });
      // }
    },
    [email, nickname, password, mismatchError],
  );
2. 타입 스크립트 공포증
2번째줄 ㄷㄷ
이게 무슨뜻인가요 제네릭인가 그거 맞죠?
타입 설정 같은데 배열 같기도 하고

type ReturnTypes<T> = [T, (e: ChangeEvent<HTMLInputElement>) => void, Dispatch<SetStateAction<T>>];

=> void dispatch는 뭔가요?
void, Dispatch<SetStateAction<T>

타입 이름이 너무 긴것도 무섭 ㅋㅋ;
ex)
ChangeEvent<HTMLInputElement>

import { Dispatch, SetStateAction, useCallback, useState, ChangeEvent } from 'react';

type ReturnTypes<T> = [T, (e: ChangeEvent<HTMLInputElement>) => void, Dispatch<SetStateAction<T>>];

const useInput = <T>(initialData: T): ReturnTypes<T> => {
  const [value, setValue] = useState(initialData);
  const handler = useCallback((e: ChangeEvent<HTMLInputElement>) => {
    setValue((e.target.value as unknown) as T);
  }, []);
  return [value, handler, setValue];
};

export default useInput;
이강의 빨리 듣고 nest js 강의 듣고 싶은데 노드 버드 강의보다 어려운거 같아요 ㅋㅋ;
전 걍 따라치는데 이강의는 미리 알아야될게 생각보다 많아요 ㅋㅋ;
보충 강의라도 .. 가 아니라 타입 스크립트를 잘알고 오는게 맞겠죠??
기초가 부족해서 그런것 같긴 한데 강의 난이도가 생각보다 너무 어렵게 느껴져요 ㅋㅋ;;

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

답변 1

0

제로초(조현영)

소스는 setting/ts로부터 시작하시는 게 좋긴 합니다. 주석처리 임시로 해도 문제는 없습니다.

type ReturnTypes<T> = [T, (e: ChangeEvent<HTMLInputElement>) => void, Dispatch<SetStateAction<T>>];

=> void dispatch는 뭔가요?

(e: ChangeEvent) => void가 하나고, Dispatch<SetStateAction<T>>가 하나입니다.

void는 undefined와 같다고 보시면 됩니다.

(e: ChangeEvent) => undefined

이건 useCallback한 handler의 타이핑입니다.

setState의 타이핑이 Dispatch<SetStateAction<T>>이고요.

여기서 공통적으로 나오는 T는 어떠한 특정 타입(사용 전에는 모르는)이라고 보시면 됩니다.

useInput('')를 하게 되면 ''는 문자열이니까 initialData: T에서 T가 string이 되고

returnTypes<T> = [T, (e: ChangeEvent<HTMLInputElement>) => void, Dispatch<SetStateAction<T>>]

에서 T도 모두 string이 됩니다.

useInput(0)을 하게 되면 T가 number가 되는 셈이고요.

ChangeEvent<HTMLInputElement> 이런건 그냥 그렇구나 하고 넘어가시면 됩니다. 이 이후로는 타입스크립트가 그렇게 많이 쓰이지는 않습니다.

기본 셋팅과 관련하여

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

190

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

460

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