inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

[리뉴얼] 타입스크립트 올인원 : Part1. 기본 문법편

enum, keyof, typeof

타입 추론 시 가장 넓은 범위로 추론이 되는 건가요?

해결된 질문

162

김성민

작성한 질문수 1

0

먼저 테스트 해 본 코드 올립니다.

const obj = { a: '123', b: 'hello', c: 'world' } as { a: string, b: `hel${string}`, readonly c: 'world' };

type AType = typeof obj;
const objA: AType = { a: '123', b: 'hello', c: 'world' }

type BType = keyof typeof obj;
const objBa: BType = 'a';
const objBb: BType = 'b';
const objBc: BType = 'c';

// CType이 string이 됩니다.
type CType = typeof obj[keyof typeof obj];

위 코드에서 CType에 마우스 커서를 올려보면 type CType = string 이라고 알려주는데 왜 그런지 몰라 여쭤봅니다.

저는 obj 객체 안의 속성들 값의 타입인 string | `hel${string}` | 'world' 로 추론될 줄 알았습니다.

이유가 `hel${string}` 타입과 'world' 타입보다 string 타입이 범위가 가장 넓기 때문에 변수를 CType으로 지정하면 string 과 차이가 없어서 그런 것일까요?

typescript

답변 1

1

제로초(조현영)

string | `hel${string}` | 'world' 이 값이 결국 string이라서 그렇습니다.

string | 'abc' 은 string 입니다

데코레이터가 현재도 자주 쓰이는 문법인가요?

0

76

2

유틸리티 타입 실제로 구현은 못해도 하나씩 외우면 실무할 때 지장 없겠죠?

0

63

1

매핑 타입은 type에서밖에 안된다고 하네요?

0

62

2

자바에서의 오버로딩과 같은 개념이라고 생각해도 되나요?

0

67

2

filter 함수 반환 타입 네로잉 질문

0

65

2

map<U>(callbackfn: ....) 할때 U는 왜 여기 있는거에요??

0

44

2

ts 컴파일을 위한 type 라벨링 부분

0

44

1

concat 함수 타입 구현 중 질문 있습니다!

0

99

2

filter 메소드 질문

0

52

1

forEach 제네릭 관련 문의

0

59

1

enum이 javascript로 트랜스파일링될때 사라진다하셨는데요

0

206

1

함수 파라미터 타입 정의 시 ...args: any[]와 ...args: any 의 차이

0

223

1

Flat type에서 ReadonlyArray 타입을 사용하는 이유?

0

156

1

bind type 질문

1

147

1

Lowercase type 관련 질문

0

151

1

key-value 타입 자동추론 질문드립니다

0

264

1

타입스크립트 교과서, p131

0

263

1

타입스크립트 교과서 p122 forEach 메서드 질문

0

231

1

타입스크립트 교과서 p116 , 코드에러남

1

268

1

타입스크립트 교과서 p112 , 코드가 안읽힙니다..

0

263

1

타입스크립트 교과서 p83

1

181

1

타입스크립트교과서 p39 쪽 코드가 이해가 안되요

1

223

1

class 에서 ts의 private vs js의 private field( # )

0

334

1

ts -> js 로 변환할 때 타입선언을 남겨두는걸 추천하는 이유

0

254

1