함수 타입 호출 시그니처
함수 타입 표현식이라고 설명하실 때는
type OnChange = (value: string) => void;호출 시그니처 설명하실 떄는
type OnChange2 = {
(value: string): void;
};이런 형태로 각각 말씀해주셨는데요
그럼 함수 타입 표현식이냐, 호출 시그니처냐 차이점은 중괄호 존재 여부인걸까요?
객체 타입처럼 정의된 것이 아니면 호출 시그니처라고 볼 수 없는지 궁금합니다
Answer 1
0
안녕하세요 루룸님 이정환입니다.
함수 타입 표현식과 호출 시그니쳐의 가장 핵심적인 차이점은 함수 타입 표현식은 해당 타입을 함수로 정의한다는 것이고, 호출 시그니쳐는 해당 타입을 객체로 정의한다는 것 입니다.
자바스크립트에서는 함수 또한 객체의 일종으로 분류되기 때문에 일반적인 객체가 그렇듯 프로퍼티를 가질 수 있습니다.
타입스크립트에서 호출 시그니처 문법을 사용하는 이유도 바로 이런 특성(함수도 프로퍼티를 가질 수 있다)을 타입 레벨에서 자연스럽게 표현하기 위해서인데요.
함수 타입 표현식은 “어떤 인자를 받아 어떤 값을 반환하는 함수”라는 호출 형태를 간결하게 나타내는 데 적합한 반면, 호출 시그니처는 여기에 더해 label 같은 추가 프로퍼티를 함께 정의하거나, 여러 형태의 호출을 오버로드처럼 묶어서 표현해야 할 때 특히 유용합니다.
즉, 두 표현은 모두 “호출 가능하다”는 의미를 담고 있지만, 호출 시그니처 쪽이 객체 타입을 기반으로 하기 때문에 확장성이 더 크다고 이해하시면 됩니다.
적절한 타입 찾기 React.ChangeEvent<HTMLInputElemen>
0
15
2
outDir 옵션 추가 후 컴파일 오류 질문
0
51
1
호출 시그니처 질문
0
63
2
서로소 유니언 타입이 discriminated union과 동의어 인가요?
0
72
2
조건부타입소개 중 함수오버로딩 활용 시 인수의타입과 함수의 반환값의 타입이 깨지는 문제
0
65
1
할인쿠폰 관련하여
0
151
2
프론트엔드에서의 인터페이스활용
0
90
2
안녕하세요 이정환님!
0
89
1
Node.js 설치에 관한 질문입니다.
0
79
2
35강. 모듈 보강은 라이브러리 파일을 직접 편집해야 하나요?
0
62
2
인터페이스 문법이 있는데 타입 별칭 문법은 왜 있나요?
0
114
4
마우스 호버 시 정보
0
90
2
vite으로 리액트 빌드하기를 업데이트해주세요.
1
89
2
타입가드를 만들어 사용하는 이유가 궁금합니다.
0
82
2
섹션 12가 너무 어려운데... 정상이겠죠..?
0
135
2
선생님.. 알고리즘도 강의해주시면안되나요
0
99
2
선생님은 어떻게 이런걸 아세요?
0
127
1
type: module
0
96
2
7:17초 업캐스팅 질문이있습니다!
0
75
1
슈퍼타입질문
1
61
2
프로젝트 설치
0
103
2
enum은 비원시 타입이면서 열거형 타입이 되는건가요?
0
67
2
함수는 함수타입? 객체타입??
1
91
2
유니온 타입의 분산적 조건부 타입
0
55
2

