Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | 5 | 6 | 7 |
8 | 9 | 10 | 11 | 12 | 13 | 14 |
15 | 16 | 17 | 18 | 19 | 20 | 21 |
22 | 23 | 24 | 25 | 26 | 27 | 28 |
29 | 30 | 31 |
Tags
- 공통컴포넌트
- typescript
- 개발콘텐츠
- 2022
- 타입스크립트
- click and drag
- React.js
- javascript
- React Native
- 커스텀
- 레이아웃쪼개기
- returnType
- 티스토리꾸미기
- 반복줄이기
- react
- NonNullable
- reactjs
- 제네릭
- const 단언문
- JS console
- 타입좁히기
- vue.js
- 성능최적화
- Chart.js
- 누구나 자료구조와 알고리즘
- 폰트적용하기
- TSDoc
- 리액트
- CSS
- utilty type
Archives
- Today
- Total
몽땅뚝딱 개발자
[TypeScript] 다형성을 고려하여 함수 타입 정하기 본문
다음 함수의 타입을 정해보자.
function filter(array, f) {
let result = []
for(let i=0; i<array.length; i++) {
let item = array[i]
if(f(item)) {
result.push(item)
}
return result
}
array에는 number, string, object 등의 다양한 타입의 배열이 들어울 수 있다.
하지만 아래처럼 작성했다간 obejct의 실제 형태를 알 수 없는 타입스크립트는 오류라고 말한다.
// 모든 타입을 받아서 난리법석이 된다.
type Filter = {
(array: number[], f: (item: number) => boolean): number[]
(array: string[], f: (item: string) => boolean): string[]
(object: string[], f: (item: Object) => boolean): object[] // error!
}
이 때 제네릭(Generic)을 사용하여 이렇게 표현해보자!
타입스크립트는 전달된 인수의 타입을 이용해 제네릭을 어떤 타입으로 한정할 지 추론한다.
number를 할당하면 number로 한정, string으로 할당하면 string으로 타입을 한정짓는다.
// 제네릭을 사용하여 이렇게 줄여보자!
// 이 타입이 무엇인지 지금은 알 수 없으니 누군가 filter를 호출할 때 마다 타입스크립트가 알아서 추론해달라는 뜻이다.
type Filter = {
<T>(array: T[], f: (item: T) => boolean): T[]
}
💡 <T>에 대한 또 다른 정보
출처
보리스 체르니, 타입스크립트 프로그래밍 (프로그래밍 인사이트, 2020)
개인적으로 공부한 내용을 정리하는 블로그로
잘못된 개념을 게시하지않도록 주의하고 있으나 오류가 있을 수 있습니다.
'Development > Typescript' 카테고리의 다른 글
[Typescript] TS2307: Cannot find module '.png' or its corresponding type declarations. (0) | 2023.10.15 |
---|---|
[TypeScript] 타입스크립트로 마이그레이션하기 (0) | 2023.01.24 |
[TypeScript] 모던 자바스크립로 작성하기 (0) | 2023.01.24 |
[TypeScript] DOM Element (0) | 2023.01.08 |
[TypeScript] 이상적으로 타입스크립트 사용하기 (0) | 2023.01.08 |
Comments