1. 인터페이스란 ?
인터페이스는 상호 간의 정의된 약속 혹은 규칙을 의미한다 타입스크립트의 인터페이스는 보통 다음과 같은 범주에 대해 약속을 정의할 수 있다
- 함수의 파라미터
- 객체의 스펙(속성과 속성의 타입)
- 함수의 스펙(파라미터, 반환 타입 등)
- 배열과 객체를 접근하는 방식
- 클래스
let person = { name: 'Capt', age: 28 };
function logAge(obj: { age: number }) {
console.log(obj.age); // 28
}
logAge(person); // 28
인터페이스에 대해 간단히 알아볼 수 있는 예제를 살펴보도록 하겠습니다 위 logAge() 함수에서 받는 인자의 형태는 age를 속성으로 갖는 객체입니다. 이렇게 인자를 받을 때 단순한 타입 뿐만 아니라 객체의 속성 타입까지 정의할 수 있죠. 만약 여기에 인터페이스를 적용하면 어떤 모습일까?
interface personAge {
age: number;
}
function logAge(obj: personAge) {
console.log(obj.age);
}
let person = { name: 'Capt', age: 28 };
logAge(person);
이제는 logAge()의 인자가 좀 더 명시적으로 바뀌었습니다. logAge()의 인자는 personAge 라는 타입을 가져야한다
그리고 위 코드를 보고 다음과 같이 추론할 수 있습니다. 인터페이스를 인자로 받아 사용할 때 항상 인터페이스의 속성 갯수와 인자로 받는 객체의 속성 갯수를 일치시키지 않아도 된다. 다시 말해, 인터페이스에 정의된 속성, 타입의 조건만 만족한다면 객체의 속성 갯수가 더 많아도 상관 없다는 의미입니다. 또한, 인터페이스에 선언된 속성 순서를 지키지 않아도 됩니다.
2. 옵션 속성
인터페이스를 사용할 때 인터페이스에 정의되어 있는 속성을 모두 다 꼭 사용하지 않아도 됩니다. 이를 옵션 속성이라고 합니다.
interface 인터페이스_이름 {
속성?: 타입;
}
이처럼 속성 끝에 '?'를 붙입니다
interface CraftBeer {
name: string;
hop?: number;
}
let myBeer = {
name: 'Saporo'
};
function brewBeer(beer: CraftBeer) {
console.log(beer.name); // Saporo
}
brewBeer(myBeer);
코드를 보면 brewBeer() 함수에서 Beer 인터페이스를 인자의 타입으로 선언했음에도 불구하고, 인자로 넘긴 객체에는 hop 속성이 없습니다. 왜냐하면 hop을 옵션 속성으로 선언했기 때문입니다.
옵션 속성의 장점은 단순히 인터페이스를 사용할 때 속성을 선택적으로 적용할 수 있다는 것 뿐만 아니라 인터페이스에 정의되어 있지 않은 속성에 대해서 인지시켜줄 수 있다는 점입니다.
3. 읽기 전용 속성
interface CraftBeer {
readonly brand: string;
}
읽기 전용 속성은 인터페이스로 객체를 처음 생성할 때만 값을 할당하고 그 이후에는 변경할 수 없는 속성을 의미합니다. 문법은 다음과 같이 readonly 속성을 앞에 붙입니다.
4. 객체 선언과 관련된 타입체킹
interface CraftBeer {
brand?: string;
}
function brewBeer(beer: CraftBeer) {
// ..
}
brewBeer({ brandon: 'what' });
위 코드를 보면 CraftBeer 인터페이스에는 brand라고 선언되어 있지만 brewBeer() 함수에 인자로 넘기는 myBeer 객체에는 brandon이 선언되어 있어 오탈자 점검을 요하는 오류가 납니다. 만약 이런 타입 추론을 무시하고 싶다면 아래와 같이 선언합니다.
let myBeer = { brandon: 'what' }';
brewBeer(myBeer as CraftBeer);
그럼에도 불구하고 만약 인터페이스 정의하지 않은 속성들을 추가로 사용하고 싶을 때는 아래와 같은 방법을 사용합니다.
interface CraftBeer {
brand?: string;
[propName: string]: any;
}
5. 함수 타입
인터페이스는 함수의 타입을 정의할 때에도 사용할 수 있습니다.
interface login {
(useName: string, password: string): boolean
}
함수의 인자의 타입과 반환 값의 타입을 정합니다.
let logInUser : login;
logInUser = function(id: string, pw: string) {
console.log('로그인 했습니다');
return true;
}
6. 인터페이스 확장
interface Person {
name: string;
}
interface Developer extends Person {
skill: string;
}
let fe = {} as Developer;
fe.name = 'josh';
fe.skill = 'TypeScript';
클래스와 마찬가지로 인터페이스도 인터페이스 간 확장이 가능합니다
'타입스크립트' 카테고리의 다른 글
[TypeScript] - 타입 추론 (0) | 2022.07.17 |
---|---|
[TypeScript] - 제네릭 (0) | 2022.07.05 |
[TypeScript] - 연산자를 이용한 타입 정의 (0) | 2022.03.30 |
[TypeScript] - 타입스크립트의 기본 타입 (0) | 2022.03.16 |
[TypeScript] - 타입스크립트란 ? (0) | 2022.02.11 |