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

이주혁님의 프로필 이미지
이주혁

작성한 질문수

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

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

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

작성

·

405

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);
});

답변 1

0

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

이주혁님의 프로필 이미지
이주혁

작성한 질문수

질문하기