강의

멘토링

로드맵

Inflearn brand logo image

인프런 커뮤니티 질문&답변

조성진/컴퓨터공학부(컴퓨터공학전공님의 프로필 이미지
조성진/컴퓨터공학부(컴퓨터공학전공

작성한 질문수

[리뉴얼] 타입스크립트 올인원 : Part1. 기본 문법편

filter 타입 직접 만들기

concat 함수 타입 구현 중 질문 있습니다!

작성

·

34

0

image.png

저는 concat 함수를 이런 식으로 구현해보았는데요,

  1. 여기서 as unknown as Arr<number> 를 사용하지 않을 수는 없을까요?

  2. lib.es5.d.ts 에서는 concat(...items: (T | ConcatArray<T>)[]): T[]; 이런 식으로 정의하고 있는데, 여기서 ConcatArray 의 쓰임세가 궁금합니다.

 

ConcatArray 의 정의를 찾아가보니

interface ConcatArray<T> {
    readonly length: number;
    readonly [n: number]: T;
    join(separator?: string): string;
    slice(start?: number, end?: number): T[];
}

이런 식으로 되어있던데 보통 Array<T>와 어떤 점이 다른 걸까요..?

답변 2

0

제로초(조현영)님의 프로필 이미지
제로초(조현영)
지식공유자

Arr이 저희가 직접 만들어낸 타입이라 어쩔수가 없습니다

ConcatArray의 역사는 조금 복잡한데요.

https://witch.work/ko/posts/typescript-concat-type-history#5-concatarray-%EB%8F%84%EC%9E%85---%EB%B0%B0%EA%B2%BD

여기에 잘 나와있습니다

감사합니다! 한번 읽어보겠습니다

0

interface Arr<T>{
    concat<U>(...values: Arr<U>[]): (T | U) [];
}

const a: Arr<number> = [1,2,3] as unknown as Arr<number>;
const b: Arr<number | string> = [1, '2', 3, '4'] as unknown as Arr<number | string>;

const c = a.concat(b, a)
const d = b.concat(a)

원본 코드입니다!

조성진/컴퓨터공학부(컴퓨터공학전공님의 프로필 이미지
조성진/컴퓨터공학부(컴퓨터공학전공

작성한 질문수

질문하기