inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

forEach 타입 직접 만들기

안녕하세요 제로초님

299

박재호

작성한 질문수 1

0

interface Arr<T> {
  forEach(callback: (aaa: T) => void): void;
}
  const test: Arr<string> = ['hello', 'world'];
  console.log(
    'test',
    test.forEach((item) => console.log('item', item))
  );

안녕하세요 제로초님 하나 궁금한것이 생겨서 여쭤보고싶습니다.
위의 사진은 정상적으로 작동하는 코드입니다.

그런데 아래 사진 같은경우는 아래 사진에 첨부한 에러 메세지가 나오고 있습니다.

둘의 차이점은 함수 이름을 forEach 를 사용했을때 에러(X)
아래 사진은 함수 이름을 forEachTest로 사용 한 것 뿐인데
forEachTest 라는 함수는 현재 에러가 나고있는데요,
해당 코드에서
forEach와 forEachTest의 차이점은 무엇인가요??
제가 생각했을땐 forEach에서도 에러가 나야 하지 않을까?
였습니다.


해당 내용이 이해가 되질 않아서 답변주시면 감사하겠습니다.

 

interface Arr<T> {
  forEachTest(callback: (aaa: T) => void): void;
}  

  const test: Arr<string> = ['hello', 'world'];
  console.log(
    'test',
    test.forEachTest((item) => console.log('item', item))
  );


typescript

답변 1

0

제로초(조현영)

interface Arr<T> extends Array<T> {
  forEachTest(callback: (aaa: T) => void): void;
}  

const test: Arr<string> = ['hello', 'world'] as Arr<string>;
console.log(
  'test',
  test.forEachTest((item) => console.log('item', item))
);
이렇게 as로 강제로 바꿔보세요. ['hello', 'world']가 Arr<string>이 아니어서 그렇습니다.

0

바스니카

interface Arr<T> {
  forEachTest(callback: (aaa: T) => void): void;
}

const test: Arr<string> = ["hello", "world"] as unknown as Arr<string>;
console.log(
  "test",
  test.forEachTest((item) => console.log("item", item))
);

이렇게 Array<T> 대신 Arr<T>로 생각하게 만들어도 에러가 안 발생하네요.

데코레이터가 현재도 자주 쓰이는 문법인가요?

0

91

2

유틸리티 타입 실제로 구현은 못해도 하나씩 외우면 실무할 때 지장 없겠죠?

0

79

1

매핑 타입은 type에서밖에 안된다고 하네요?

0

75

2

자바에서의 오버로딩과 같은 개념이라고 생각해도 되나요?

0

80

2

filter 함수 반환 타입 네로잉 질문

0

83

2

map<U>(callbackfn: ....) 할때 U는 왜 여기 있는거에요??

0

59

2

ts 컴파일을 위한 type 라벨링 부분

0

55

1

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

0

110

2

filter 메소드 질문

0

62

1

forEach 제네릭 관련 문의

0

66

1

타입 추론 시 가장 넓은 범위로 추론이 되는 건가요?

0

170

1

enum이 javascript로 트랜스파일링될때 사라진다하셨는데요

0

213

1

함수 파라미터 타입 정의 시 ...args: any[]와 ...args: any 의 차이

0

229

1

Flat type에서 ReadonlyArray 타입을 사용하는 이유?

0

163

1

bind type 질문

1

158

1

Lowercase type 관련 질문

0

154

1

key-value 타입 자동추론 질문드립니다

0

276

1

타입스크립트 교과서, p131

0

273

1

타입스크립트 교과서 p122 forEach 메서드 질문

0

239

1

타입스크립트 교과서 p116 , 코드에러남

1

281

1

타입스크립트 교과서 p112 , 코드가 안읽힙니다..

0

272

1

타입스크립트 교과서 p83

1

189

1

타입스크립트교과서 p39 쪽 코드가 이해가 안되요

1

233

1

class 에서 ts의 private vs js의 private field( # )

0

341

1