inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

타입스크립트 입문 - 기초부터 실전까지

제네릭 실전 예제 살펴보기 - 제네릭을 이용한 타입 정의

유니온 없앴는데 맞게 한건가요??

450

이주혁

작성한 질문수 3

2

interface Generic<T> {
  value: T;
  selected: boolean;
}

const emails: Generic<string>[] = [
  { value: "naver.com", selected: true },
  { value: "gmail.com", selected: false },
  { value: "hanmail.net", selected: false },
];


const numberOfProducts: Generic<number>[] = [
  { value: 1, selected: true },
  { value: 2, selected: false },
  { value: 3, selected: false },
];

function createDropdownItem(item : Generic<string>):HTMLOptionElement {
  const option = document.createElement("option");
  option.value = item.value.toString();
  option.innerText = item.value.toString();
  option.selected = item.selected;
  return option;
}

// NOTE: 이메일 드롭 다운 아이템 추가
emails.forEach(function (email : Generic<string>): void {
  const item = createDropdownItem(email);
  const selectTag = document.querySelector("#email-dropdown");
  selectTag.appendChild(item);
});

javascript typescript es6

답변 1

0

캡틴판교

네 작성하신 코드가 VSCode 상에서 에러가 나지 않으면 문제 없을 것 같아요. 다만, Generic이라는 인터페이스 명은 지양하셔야 할 것 같습니다 :)

TSLint

0

77

1

vscode eslint server 오류

0

96

1

안녕하세요. 기본타입- 튜플, 객체, 진위값 부분의 영상의 화면이 나오질 않습니다.

0

84

1

live server 설치 오류

1

395

2

강의 교안 pdf 는 따로 제공하지않나요?

0

294

2

npm i 설치 이유 문의

1

425

3

index.ts Delete &#x60;␍&#x60;eslintprettier/prettier 오류(빨간줄) 해결

2

302

3

vue 에서 jquery 사용 문제

1

708

2

TSLint 확장 프로그램은 현재 지원하지 않는다고 합니다.

1

508

2

강의 내용처럼 노란 밑줄이 작동하지 않아서 유사 질문들을 실행해보았는데요

1

551

1

section 3-1 JSdoc 타입이 추론되지 않아서 다음과 같이 수정했는데 이거 맞나요?

1

463

2

함수에 리턴 안됐다고 노란밑줄이 쳐져야하는데 없습니다

2

461

1

파일이 다른데 식별자가 중복되었다고 뜹니다.

1

458

2

빨간줄 에러 질문드립니다

1

497

2

마우스 갖다대면 리턴값 설명 나오는 거 질문드려요

1

365

2

js에서 @ts-check 적어도 체크하지 못하는 문제입니다

2

403

2

index.html에서 타입스크립트 콘솔 찍는 법 질문드립니다

1

574

2

섹션 1-3 추론 질문드립니다

1

361

2

왜 api쪽에는 왜 에러가 안나는지 궁금합니다.

1

332

2

const item1을 선언했을 때 타입을 선언해줘도 괜찮을까요?

1

403

1

전화번호부 타입선언

1

271

2

타입을 전역으로 분리

1

601

2

객체 선언 시 구분자는 쉼표, 세미콜론 모두 사용가능한건가요?

1

461

1

Git 관련 질문이 있습니다

1

674

2