inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

회원가입 페이지 만들기

파라미터 타입지정

409

도토잠보

작성한 질문수 4

1

안녕하세요 ! 

저는 이번에 웹팩 및 바벨 설정부터 죽 타입핑을 하며 익히고 잇는데요,  SignUp > index.tsx 부분의 일부코드인데 보시는 바와 같이 영상속 제로초님과는 다르게 `e`의 타입을 지정해주지 않으면 로컬자체가 켜지지 않더라고여 😅 혹시 제가 어느부분때문에 제로초님과 다르게 진행되고있는지 알 수 있을까요 ?

  const onChangeEmail = useCallback((e: any) => {
    setEmail(e.target.value);
  }, []); 

  const onChangeNickname = useCallback((e: any) => {
    setNickname(e.target.value);
  }, []);

  const onChangePassword = useCallback(
    (e: any) => {
      setPassword(e.target.value);
      setMissmatchError(e.target.value !== passwordCheck);
    },
    [passwordCheck], 
  );

  const onChangePasswordCheck = useCallback(
    (e: any) => {
      setPasswordCheck(e.target.value);
      setMissmatchError(e.target.value !== password);
    },
    [password],
  );

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

답변 2

2

hoon

React.ChangeEvent<HTMLInputElement>로 적어줘야하네요.

<input onChange={(e) => e}> 라고 친다음에 e위에 마우스커서 올리면 IDE가 어떤 타입인지 알려줍니다.

0

제로초(조현영)

e에 any를 입력하지 않았을 때 발생하는 애러가 뭔가요?

0

도토잠보

ERROR in ./pages/SignUp/index.tsx:16:6
TS7006: Parameter 'e' implicitly has an 'any' type.
    14 |
    15 |   const onChangePassword = useCallback(
  > 16 |     (e) => {
       |      ^
    17 |       setPassword(e.target.value);
    18 |       setMissmatchError(e.target.value !== passwordCheck);
    19 |     },

sleact (webpack 5.72.1) compiled with 1 error in 555 ms

입니당

1

제로초(조현영)

네네 저게 뜨면 매개변수에도 타입 붙여주어야 합니다.

0

도토잠보

답변너무 감사합니다 🙇‍♂️

질문을 하나 더 드려도 될까요 ?

어째서 제로초님은 파라미터 타입을 설정하지 않았는데도 에러가 나지 않는건가요 ? 🤔

1

제로초(조현영)

리액트 몇 버전이신가요? 리액트 17버전에서는 useCallback의 e가 any로 자동 타이핑되어 있습니다.

0

도토잠보

package.json 확인해보니 18.1.0 사용되고 있습니당

1

제로초(조현영)

그러면 아마 타이핑이 바뀌었을 수 있습니다. @types/react 에서요.

0

도토잠보

아아.. 어쩔수없는 부분이군요..ㅠㅠ 바쁘신데 답변너무감사드립니다 !!!!!!!

3

제로초(조현영)

onSubmit같은 것은 e: React.FormEvent 이고 그냥 input은 e: React.ChangeEvent 입니다.

0

도토잠보

답변 너무 감사드립니다 ㅠㅠ 저러한 타입지정같은경우 구글링하면서 배워나가는게 더 나은가요? 아니면 인강이나 책보고 공부를 하는게 더 나을까요 ? 🤔

0

제로초(조현영)

typescript 자체가 일종의 문서이므로 직접 타입들 확인하는 연습을 하셔야 합니다. 인강이나 책은 쓰는 타입만 써서 한계가 있습니다.

0

도토잠보

답변너무너무 감사드립니다 ㅠㅠ 오늘 정말 많이 알아가네요 ! 답변참고해서 공부방향 잡도록 할게요 감사합니다 !!

기본 셋팅과 관련하여

0

109

1

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

0

110

2

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

0

167

2

useEffect 개수 관리

0

123

2

라이브러리 서치 방법

0

118

2

함수 정의 패턴

0

81

1

npm run dev 에러

0

157

3

npx webpack 후 에러

0

189

2

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

0

154

2

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

1

193

2

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

0

163

2

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

0

440

3

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

0

610

2

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

0

971

1

배포 방법

0

307

2

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

0

1017

2

alias 경로 설정 오류

0

463

2

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

0

284

1

제네릭 질문

0

227

2

ts-node 대신 tsx 사용여부

0

380

1

배포 관련 질문

0

249

1

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

0

396

2

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

0

343

1

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

0

255

2