5.3 함수 타입의 호환성
타입스크립트가 함수 타입 간의 호환성을 판단하는 법에 대해 다룬다.
매개변수 수가 같은 경우
함수 타입 간의 호환성을 판단하려 할 때, 가장 간단한 경우는 두 함수의 매개변수의 갯수가 같은 경우다. 이 때, 할당을 받는 함수의 타입을 Target, 할당하려는 함수의 타입을 Source라 하자.
let source: Source;
const target: Target = source;위 코드가 허용되는지, 즉 Target이 Source에 할당 가능한지를 보기 위해선 다음 두 질문에 답해야 한다.
Target과Source의 모든 매개변수 타입에 대해,Source의 매개변수 타입이Target의 매개변수 타입에 할당 가능한가?Target의 반환 타입이Source의 반환 타입에 할당 가능한가?
두 질문에 대한 답이 모두 “예”라면, Target은 Source에 할당 가능하다.
할당 가능한 경우
먼저 할당 가능한 경우를 살펴보자.
type Sum = (sumFirst: number, sumSecond: number) => number;
type Multiply = (mulFirst: number, mulSecond: number) => number;모든 매개변수 타입은
number로, 서로 할당 가능하다.Multiply의 반환 타입인number는Sum의 반환 타입인number에 할당 가능하다.
따라서 Sum은 Multiply에 할당 가능하다.
const sum: Sum (sumFirst: number, sumSecond: number) => {
return sumFirst + sumSecond;
};
const multiply: Multiply = sum; // ok할당 불가능한 경우
다음으로는 할당이 불가능한 예제를 살펴보자.
interface Animal { animalProp: string };
interface Dog extends Animal { dogProp: number };
let f = (animal: Animal) => animal.animalProp;
let g = (dog: Dog) => { doSomething(dog.dogProp) };
f = g;할당받는 함수의 매개변수 타입
Animal은 할당하는 함수의 매개변수 타입Dog에 할당 불가능하다.
만족되지 않는 기준이 있으므로 g는 f에 할당할 수 없다.
매개변수 수가 다른 경우
매개변수 수가 같은 두 함수의 호환성을 비교하는 법에 대해 살펴봤다. 이번엔 매개변수의 수가 다른 경우엔 상황이 어떻게 달라지는지를 다음 두 함수 타입을 통해 살펴보자.
type Login = (id: string) => Response<Data>;
type LoginWithToken = (id: string, token: string) => Response<Data>;할당하는 함수의 매개변수 수가 더 많은 경우
아래 코드에서 할당하는 함수인 loginWithToken은 할당받는 함수 login에 비해 token: string 이라는 매개변수를 추가적으로 갖고 있다.
const loginWithToken: LoginWithToken = (id: string, token: string) => { /* ... */ };
const login: Login = loginWithToken;이런 경우는 할당이 불가능하다. 만약 이 할당을 허용한다고 생각해보자. 프로그래머는 이 함수를 다음과 같은 식으로 호출할 것이다.
login('myId');이는 loginWithToken 함수를 token 인자 없이 호출하는 셈이다. loginWithToken 함수 내에서 token을 string 타입이라 생각하고 사용했다면, string이 필요한 자리에 undefined 값이 넘어와서 런타임 에러가 발생할 것이다. 따라서 이런 할당은 허용되지 않는다.
할당받는 함수의 매개변수 수가 더 많은 경우
아래 코드에서 할당하는 함수인 login은 할당받는 함수인 loginWithToken에 비해 매개변수 수가 하나 모자라다.
const login: Login = (id: string) => { /* ... */ };
const loginWithToken: LoginWithToken = login;이런 경우, 초과 매개변수는 무시된다. 그리고 매개변수 수가 같을 때와 동일한 알고리즘으로 호환성을 판단한다. 위의 경우, 초과 매개변수인 token: string 을 제외하고 첫 번째 매개변수는 동일한 타입을 가지므로 할당은 문제 없이 진행된다.
Last updated