강의

멘토링

커뮤니티

Inflearn Community Q&A

devleeee's profile image
devleeee

asked

[Renewal] TypeScript All-in-One: Part 1. Basic Syntax

Required, Record, NonNullable type analysis

선생님 제네릭에 관해서 질문 사항이 있습니다.

Resolved

Written on

·

476

0

문자열 또는 숫자를 인자로 받아서
문자열 인자인 경우는 문자열 결합을
숫자 인자인 경우에는 숫자 덧셈을 구현하는 함수를 구현하려고 했습니다. 그런데 아래와 같은 에러가 뜨는데 제 짧은 지식으로는 도대체 이해가 안되서 질문을 남깁니다.

또한, 제네릭 타입의 변수는 type guard를 해줄 방법이 없는건가요?

n1과 n2의 타입은 T & 'string' 또는 T & 'number'으로 추론합니다.

 

스크린샷 2023-02-14 오후 3.39.07.png

typescript

Answer 3

1

위와 같이 둘 다 같은 타입으로 바꾸시면 됩니다. 처음에 짤 때 하나씩만 바꿔서 문제가 생겼나 봅니다.
(a | b) & a = (a & a) | (b & a) = a | never = a
이런식으로 연산이 되니까 타입가드는 가능한데요. 연습이 아니라면 굳이 위의 코드를 제네릭으로 짤 필요는 없을 거 같긴 해요

1

function sum<T extends number | string>(n1: T | null, n2: T | null) {
    if(typeof n1 === 'string' && typeof n2 === 'string') {
        return n1 + n2 
    }
    return
}

0

zerocho님의 프로필 이미지
zerocho
Instructor

The comment has been deleted

devleeee님의 프로필 이미지
devleeee
Questioner

그럼 이 경우에는 무조건 오버로딩 밖에 답이 없는건가요??

devleeee's profile image
devleeee

asked

Ask a question