색인된 접근 타입
색인된 접근 타입(indexed access type)을 사용하여 다른 타입의 특정 프로퍼티를 조회할 수 있습니다.
ts
typePerson = {age : number;name : string;alive : boolean };typeAge =Person ["age"];
ts
typePerson = {age : number;name : string;alive : boolean };typeAge =Person ["age"];
색인된 타입 자체가 타입이므로 합집합, keyof
, 또는 기타 타입을 모두 사용할 수 있습니다.
ts
typeI1 =Person ["age" | "name"];typeI2 =Person [keyofPerson ];typeAliveOrName = "alive" | "name";typeI3 =Person [AliveOrName ];
ts
typeI1 =Person ["age" | "name"];typeI2 =Person [keyofPerson ];typeAliveOrName = "alive" | "name";typeI3 =Person [AliveOrName ];
존재하지 않는 프로퍼티에 접근하려고 하면 오류가 표시됩니다.
ts
typeProperty 'alve' does not exist on type 'Person'.2339Property 'alve' does not exist on type 'Person'.I1 =Person ["alve" ];
ts
typeProperty 'alve' does not exist on type 'Person'.2339Property 'alve' does not exist on type 'Person'.I1 =Person ["alve" ];
임의의 타입으로 색인화하는 또 다른 예는 number
를 사용하여 배열 요소의 타입을 가져오는 것입니다. 이를 typeof
와 결합하여 배열 리터럴의 요소 타입을 편리하게 포착할 수 있습니다.
ts
constMyArray = [{name : "Alice",age : 15 },{name : "Bob",age : 23 },{name : "Eve",age : 38 },];typePerson = typeofMyArray [number];typeAge = typeofMyArray [number]["age"];// 또는typeAge2 =Person ["age"];
ts
constMyArray = [{name : "Alice",age : 15 },{name : "Bob",age : 23 },{name : "Eve",age : 38 },];typePerson = typeofMyArray [number];typeAge = typeofMyArray [number]["age"];// 또는typeAge2 =Person ["age"];
색인화할 때만 타입을 사용할 수 있습니다. 즉, const
를 사용하여 변수 참조를 만들 수 없습니다.
ts
constkey = "age";typeType 'key' cannot be used as an index type.Age =Person []; key
'key' refers to a value, but is being used as a type here. Did you mean 'typeof key'?2538
2749Type 'key' cannot be used as an index type.
'key' refers to a value, but is being used as a type here. Did you mean 'typeof key'?
ts
constkey = "age";typeType 'key' cannot be used as an index type.Age =Person []; key
'key' refers to a value, but is being used as a type here. Did you mean 'typeof key'?2538
2749Type 'key' cannot be used as an index type.
'key' refers to a value, but is being used as a type here. Did you mean 'typeof key'?
그러나 유사한 스타일의 리팩터링에 타입 별칭을 사용할 수 있습니다.
ts
typekey = "age";typeAge =Person [key ];
ts
typekey = "age";typeAge =Person [key ];