Interface
TypeScript에서, 인터페이스는 상호 간에 정의한 약속 혹은 규칙을 의미합니다.
타입스크립트에서의 인터페이스는 보통 다음 과 같은 범주에 대해 약속을 정희 할수 있습니다.
- 객체의 스펙(속성과 속성의 타입)
- 함수의 파라미터
- 함수의 스펙(파라미터, 반환 타입 등)
- 배열과 객체를 접근하는 방식
- 클래스
Interface 간단한 예제
let person = { name: 'Capt', age: 28 };
function logAge(obj: { age: number }) { console.log(obj.age); // 28 }
logAge(person); // 28
위 logAge() 함수에서 받는 인자의 형태는 age 속성을 갖는 객체입니다.
이렇게 인자를 받을 떄 단순한 타입 뿐만 아니라 객체의 속성 타입까지 정의 할 수 있다.
아래는 Inteface 적용 예
interface personAge { age: number; }
function logAge(obj: personAge) { console.log(obj.age); }
let person = { name: 'Capt', age: 28 }; logAge(person);
이제는 logAge() 의 인자가 좀 더 명시적으로 바뀌었습니다.
logAge() 의 인자는 personAge 라는 타입을 가져야합니다.
그리고 위 코드를 보고 다음과 같이 추론할 수 있습니다. 인터페이스를 인자로 받아 사용할 때 항상 인터페이스의 속성 갯수와 인자로 받는 객체의 속성 갯수를 일치시키지 않아도 된다. 다시 말해, 인터페이스에 정의된 속성, 타입의 조건만 만족한다면 객체의 속성 갯수가 더 많아도 상관 없다는 의미입니다. 또한, 인터페이스에 선언된 속성 순서를 지키지 않아도 됩니다.
옵션 속성
인터페이스를 사용할 떄 인터페이스에 정의되어 있는 속성을 모두 다 꼭 사용하지 않아도 됩니다. 이를 옵션 속성이라고 합니다.
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을 옵션 속성으로 선언했기 때문입니다.
옵션 속성의 장점
옵션 속성의 장점은 단순히 인터페이스를 사용할 때 속성을 선택적으로 적용할 수 있다는 것 뿐만 아니라 인터페이스에 정의되어 있지 않은 속성에 대해서 인지시켜줄 수 있다는 점입니다.
interface CraftBeer {
name: string;
hop?: number;
}
let myBeer = {
name: 'Saporo'
};
function brewBeer(beer: CraftBeer) {
console.log(beer.brewery); // Error: Property 'brewery' does not exist on type 'Beer'
}
brewBeer(myBeer);
인터페이스에 정의되어 있지 않은 속성에 대해서 오류를 표시합니다.
읽기 전용 속성
읽기 전용 속성은 인터페이스로 객체를 처음 생성할 때만 값을 할당하고 그 이후에는 변경할 수 없는 속성을 의미합니다. 문법은 다음과 같이 readonly 속성을 앞에 붙입니다.
interface CraftBeer {
readonly brand: string;
}
let mybeer: CraftBeer = {
brand: 'Tera'
};
mybeer.brand = 'Tera is Good' // error!
인터페이스로 객체를 선언하고 나서 수정하려고 하면 오류가 납니다.
읽기 전용 배열
배열을 선언할 때 ReadonlyArray 타입을 사용하면 읽기 전용 배열을 생성할 수 있습니다.
let arr: ReadonlyArray<number> = [1,2,3];
arr.splice(0,1); // error
arr.push(4); // error
arr[0] = 100; // error
위처럼 배열을 ReadonlyArray로 선언하면 배열의 내용을 변경할 수 없습니다.
함수 타입
인터페이스는 함수의 타입을 정의할 떄에도 사용이 가능합니다.
interface login {
(username: string, password: string): boolean;
}
let loginUser: login;
loginUser = function(id: string, pw: string) {
console.log('로그인 했습니다');
return true;
}
함수의 인자의 타입과 반환 값의 타입을 정합니다.
클래스 타입
클래스가 일정 조건을 만족하도록 타입 규칙을 정할 수 있습니다.
interface CraftBeer {
beerName: string;
nameBeer(beer: string): void;
}
class myBeer implements CraftBeer {
beerName: string = 'Baby Guinness';
nameBeer(b: string) {
this.beerName = b;
}
constructor() {}
}
인터페이스 확장
클래스와 마찬가지로 인터페이스도 인터페이스 간 확장이 가능합니다.
interface Person {
name: string;
}
interface Developer extends Person {
skill: string;
}
let fe = {} as Developer;
fe.name = 'josh';
fe.skill = 'TypeScript';
'typescript' 카테고리의 다른 글
1. TypeScript Type System (1) | 2024.03.10 |
---|