상식닷컴
로그인
가입하기
2026년 상식닷컴 선정 식당 & 카페 리스트
2025년 2026년 신상 호텔 리스트
최근에 오픈한 호텔을 찾는다면 살펴보세요
일주일 식단표 어플
자동 일주일 식단표 어플
안드로이드
아이폰
주식 & 코인 차트의 신
1000만원으로 2000만원 만들기 프로젝트
수정하기 - 타입스크립트에서 타입을 조합하는 방법은 무엇인가요?
닉네임
비밀번호
제목
내용
[이미지 업로드는 권한이 있는 사람만 가능. 하단 카톡으로 연락]
타입스크립트(<a href='https://sangseek.com/sangseeks/TypeScript/ko'>TypeScript</a>)는 <a href='https://sangseek.com/sangseeks/자바/ko'>자바</a>스크립트의 상위 집합으로, 정적 타입을 지원하여 코드의 안정성을 높이고 개발자 경험을 향상시키는 데 도움을 줍니다. 타입스크립트에서 타입을 조합하는 방법은 여러 가지가 있으며, 이를 통해 복잡한 데이터 구조를 정의하고, 코드의 재사용성을 높일 수 있습니다. 아래에서는 타입 조합의 주요 방법에 대해 자세히 설명하겠습니다. 1. 유니온 타입 (Union Types) 유니온 타입은 여러 타입 중 하나를 허용하는 타입입니다. `|` 기호를 사용하여 여러 타입을 조합할 수 있습니다. ```typescript type StringOrNumber = string | number; function printValue(value: StringOrNumber) { console.log(value); } printValue("Hello"); // 문자열 printValue(42); // 숫자 ``` 2. <a href='https://sangseek.com/sangseeks/인터섹션 타입/ko'>인터섹션 타입</a> (Intersection Types) 인터섹션 타입은 여러 타입을 결합하여 모든 타입의 속성을 포함하는 새로운 타입을 생성합니다. `&` 기호를 사용하여 타입을 조합합니다. ```typescript interface Person { name: string; age: number; } interface Employee { employeeId: number; } type EmployeePerson = Person & Employee; const employee: EmployeePerson = { name: "John", age: 30, employeeId: 12345 }; ``` 3. <a href='https://sangseek.com/sangseeks/제네릭/ko'>제네릭</a> (<a href='https://sangseek.com/sangseeks/Generics/ko'>Generics</a>) 제네릭은 타입을 매개변수로 받아 다양한 타입에 대해 재사용 가능한 <a href='https://sangseek.com/sangseeks/컴포넌트/ko'>컴포넌트</a>를 만들 수 있게 해줍니다. 제네릭을 사용하면 타입을 조합하여 더 유연한 코드를 작성할 수 있습니다. ```typescript function identity<T>(arg: T): T { return arg; } let output = identity<string>("Hello"); let numberOutput = identity<number>(42); ``` 4. 튜플 (Tuples) 튜플은 고정된 수의 요소를 가지며 각 요소가 서로 다른 타입을 가질 수 있는 배열입니다. 이를 통해 여러 타입을 조합하여 사용할 수 있습니다. ```typescript type StringNumberTuple = [string, number]; const tuple: StringNumberTuple = ["Hello", 42]; ``` 5. 타입 <a href='https://sangseek.com/sangseeks/별칭/ko'>별칭</a> (Type Aliases) 타입 별칭을 사용하면 복잡한 타입을 간단하게 정의할 수 있습니다. 이를 통해 여러 타입을 조합하여 새로운 타입을 만들 수 있습니다. ```typescript type Point = { x: number; y: number; }; type Circle = Point & { radius: number; }; const circle: Circle = { x: 0, y: 0, radius: 5 }; ``` 6. 맵드 타입 (Mapped Types) 맵드 타입은 기존 타입을 기반으로 새로운 타입을 생성하는 방법입니다. 이를 통해 객체의 속성을 변형하거나 추가할 수 있습니다. ```typescript type Person = { name: string; age: number; }; type ReadOnly<T> = { readonly [K in keyof T]: T[K]; }; type ReadOnlyPerson = ReadOnly<Person>; const person: ReadOnlyPerson = { name: "Alice", age: 25 }; // person.age = 26; // 오류 발생: 읽기 전용 속성 ``` 7. 조건부 타입 (Conditional Types) 조건부 타입은 타입이 특정 조건을 만족하는지에 따라 다른 타입을 선택할 수 있게 해줍니다. ```typescript type IsString<T> = T extends string ? "Yes" : "No"; type Test1 = IsString<string>; // "Yes" type Test2 = IsString<number>; // "No" ``` 결론 타입스크립트에서 타입을 조합하는 방법은 다양하며, 이를 통해 복잡한 데이터 구조를 효과적으로 정의하고 관리할 수 있습니다. 유니온 타입, 인터섹션 타입, 제네릭, 튜플, 타입 별칭, 맵드 타입, 조건부 타입 등을 적절히 활용하면 코드의 가독성과 재사용성을 높일 수 있습니다. 이러한 기능들을 잘 이해하고 활용하면 타입스크립트의 강력한 타입 시스템을 최대한 활용할 수 있습니다.
이용안내
커뮤니티 이용안내
×
- 게시한 게시글로 발생하는 문제는 게시자에게 책임이 있습니다.
- 게시글이 타인/타업체의 저작권을 침해할 경우 모든 책임은 게시자에게 있습니다. 게시자가 모든 손해를 부담해야 합니다.
- 상식닷컴 운영자는 게시자와 상의하지 않고 게시글을 수정 또는 삭제할 수 있습니다.
- 상식닷컴 운영자는 깨끗한 커뮤니티 공간을 만드는 것이 1순위입니다.
수정하기
취소하기