inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

한 입 크기로 잘라먹는 타입스크립트(TypeScript)

타입스크립트 템플릿 소개

template typescript로 react 앱을 만드록 배포는 어떻게 하나요?

637

김강연

작성한 질문수 11

0

template typescript로 react-app을 초기화하면 tsconfig.json파일에 compilerOptions에 지금까지 배운 outDir은 없고 noEmit: true가 기본으로 되어 있는데 이게 complie할 때 js파일을 만들지 않는 설정 이더군요.

지금까지 typescript를 들은 바로는 typescript는 오류를 방지 하기 위한 방법으로만 파일 작성을 하고 그 자체로는 뭔가 부족?(문법이 호환이 안된다 하셨나?) 그래서 파일을 javascript로 complie 하고 배포가 되는 걸(용이해서/어짜피 .js파일로 실행시켜야하기 때문에)로 알고 있습니다.

이렇게 설정된 이유가 제가 모르는 다른 이유가 있나요? 아니면 단순한 default 설정이고

결국 outDir/ noEmit: false로 설정해서 파일 변환을 하고 배포해야하는건가요?

혹시 그냥 ts-node로 실행시킨다는 마인드인가요?

typescript

답변 1

0

이정환 Winterlood

안녕하세요 이정환입니다.

typescript template으로 리액트 앱을 생성하셨을때 noEmit 옵션이 설정된 이유는
CRA로 만들어진 리액트 앱에서는 TSC가 아닌 Babel이 타입스크립트를 컴파일 하기 때문입니다.
따라서 TSC는 타입 체킹 정도의 역할만 할 뿐 실제 트랜스파일링(컴파일)은 Babel이 수행하게 됩니다.

따라서 배포하실 때에는 기존의 리액트 앱을 사용하셨을 때와 동일하게 그냥 npm run build 이후 빌드 파일을 배포하시면 됩니다.

핸드북 light/dark mode 관련 이슈가 있는 것 같습니다.

0

20

1

제네릭 클래스 핸드북 페이지가 undefined라고 나옵니다.

0

30

2

적절한 타입 찾기 React.ChangeEvent<HTMLInputElemen>

0

36

2

outDir 옵션 추가 후 컴파일 오류 질문

0

80

1

호출 시그니처 질문

0

72

2

서로소 유니언 타입이 discriminated union과 동의어 인가요?

0

84

2

조건부타입소개 중 함수오버로딩 활용 시 인수의타입과 함수의 반환값의 타입이 깨지는 문제

0

72

1

할인쿠폰 관련하여

0

168

2

프론트엔드에서의 인터페이스활용

0

100

2

안녕하세요 이정환님!

0

97

1

Node.js 설치에 관한 질문입니다.

0

82

2

함수 타입 호출 시그니처

0

63

1

35강. 모듈 보강은 라이브러리 파일을 직접 편집해야 하나요?

0

70

2

인터페이스 문법이 있는데 타입 별칭 문법은 왜 있나요?

0

122

4

마우스 호버 시 정보

0

98

2

vite으로 리액트 빌드하기를 업데이트해주세요.

1

92

2

타입가드를 만들어 사용하는 이유가 궁금합니다.

0

89

2

섹션 12가 너무 어려운데... 정상이겠죠..?

0

141

2

선생님.. 알고리즘도 강의해주시면안되나요

0

105

2

선생님은 어떻게 이런걸 아세요?

0

136

1

type: module

0

102

2

7:17초 업캐스팅 질문이있습니다!

0

84

1

슈퍼타입질문

1

70

2

프로젝트 설치

0

116

2