inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

커스텀 훅 만들기

타입스크립트에 질문드립니다.

359

우동이

작성한 질문수 23

0

자주 질문드려서 죄송합니다!! 

타입스크립트를 활용하는 부분이 여기서 처음 나오는 것 같은데요.

제가 타입스크립트를 배웠을 때에는 추론이 되더라도 장점을 살리기 위해 왠만하면 다 붙여주는 것으로 알고 있습니다. 하지만 현재 프로젝트에서는 추론되어지는건 생략하고 추론되어지지 않는 부분만 타입스크립트를 사용하시는 것 같아서요. 혹시 이게 더 좋은 방법이고 현업에서도 이렇게 이루어지는지 궁금합니다!

마지막으로 한가지 더 질문드립니다.

onChange같은 경우는React.ChangeEvent<HTMLInputElement> 을 활용하면 any를 사용하지 않고 오류를 발생하지 않는것으로 알고 있습니다. 밑에 코드처럼 이렇게 작성하면 되는지 궁금합니다!

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

const useInput = <T = any>(
  initialData: T,
): [T, (e: React.ChangeEvent<HTMLInputElement>) => void, Dispatch<SetStateAction<T>>] => {
  const [value, setValue] = useState(initialData);

  const handler = useCallback((e) => {
    setValue(e.target.value);
  }, []);

  return [value, handler, setValue];
};

export default useInput;

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

답변 4

1

제로초(조현영)

요즘 에디터에서 함수에 손을 올려보면 매개변수 타입과 리턴 타입이 다 뜨는지라 굳이 명시할 필요가 있나 잘 모르겠습니다.

추가로 적어주신 코드는 제 강좌 소스 코드에 보시면 나와 있습니다.

https://github.com/ZeroCho/sleact/blob/master/alecture/hooks/useInput.ts

1

제로초(조현영)

추론되는 게 부정확한 경우에만 붙이시면 됩니다. 추론이 정확한 경우 굳이 추론 내용을 다시 적을 필요가 없습니다. 추론이 정확한 걸 다시 그대로 써서 얻을 수 있는 장점이 있나요?

0

우동이

항상 답변해주셔서 감사합니다. 더 열심히 공부해보겠습니다!

0

우동이

타입스크립트를 활용해 어떤 타입의 인자가 들어오고 어떤 타입을 return하는지를 명시함으로써 협업을 통해 개발할 때 생산성 측면에서 좀 더 좋을 것 같다는 생각을 해서요! 오히려 추론되어지는 부분을 생략해버리는 것이 더 좋은지 잘 모르겠어서 질문드렸습니다.

기본 셋팅과 관련하여

0

90

1

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

0

95

2

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

0

148

2

useEffect 개수 관리

0

108

2

라이브러리 서치 방법

0

103

2

함수 정의 패턴

0

77

1

npm run dev 에러

0

151

3

npx webpack 후 에러

0

177

2

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

0

142

2

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

1

176

2

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

0

154

2

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

0

426

3

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

0

598

2

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

0

949

1

배포 방법

0

295

2

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

0

985

2

alias 경로 설정 오류

0

446

2

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

0

273

1

제네릭 질문

0

216

2

ts-node 대신 tsx 사용여부

0

373

1

배포 관련 질문

0

243

1

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

0

382

2

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

0

332

1

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

0

244

2