3.7 filter 만들기

    이번에는 filter 메서드를 타이핑해보겠습니다. 이미 forEachmap 메서드를 타이핑해보았으므로 첫 타이핑을 조금 더 구체적으로 했습니다.

    const r1 = [1, 2, 3].myFilter((v) => v < 2);
    // const r1: number[]
    const r2 = [1, 2, 3].myFilter((v, i, a) => {});
    // const r2: number[]
    const r3 = ['1', 2, '3'].myFilter((v) => typeof v === 'string');
    // const r3: (string | number)[]
    const r4 = [{ num: 1 }, { num: 2 }, { num: 3 }].myFilter(function(v) {
      return v.num % 2;
    });
    /*
    const r4: {
      num: number;
    }[]
    */

     

    interface Array<T> {
      myFilter(callback: (v: T, i: number, a: T[]) => void, thisArg?: any): T[];
    }
    
    신간 소식 구독하기
    뉴스레터에 가입하시고 이메일로 신간 소식을 받아 보세요.