1. 타입 선언
TypeScript는 다음 같이 변수 명 뒤에 타이븡ㄹ 명시하는 것으로 타입을 선언 할 수 있다.
1 | //변수 foo는 string 타입이다. |
선언한 타입에 맞지않는 값을 할당하면 컴파일 시점에서 에러가 발생한다.
1 | let bar:number = true; //Error |
이러한 타입선언을 개발자가 코드를 에측할 수 있도록 돕는다. 또한 타입 선언은 강력한 타입체크를 가능하게 하여 문법 에러나 타입고 일치 하지않는 할당 증 기본적인 오류는 런타임 이전에 검출한다.
함수의 매개변수와 반환값에 대한 타입 선언 방법은 다음과 같다. 일반 변수와 마찬가지로 선언된 타입에 일치 하지 않는 값이 주어지면 에러가 발생한다.
1 | //함수 선언식 |
TypeScript는 ES5, ES6의 상위확장이므로 자바스크립트의 타입을 그대로 사용할 수 있다. 자바스크립트 타입 이외에도 TypeScript 고유의 타입이 추가로 제공된다.
Type | JS | TS | Description |
---|---|---|---|
boolean | ◯ | ◯ | true와 false |
null | ◯ | ◯ | 값이 없다는 것을 명시 |
undefined | ◯ | ◯ | 값을 할당하지 않은 변수의 초기값 |
number | ◯ | ◯ | 숫자(정수와 실수, Infinity, NaN) |
string | ◯ | ◯ | 문자열 |
symbol | ◯ | ◯ | 고유하고 수정 불가능한 데이터 타입이며 주로 객체 프로퍼티들의 식별자로 사용(ES6에서 추가) |
object | ◯ | ◯ | 객체형(참조형) |
array | ◯ | 배열 | |
tuple | ◯ | 고정된 요소수 만큼의 타입을 미리 선언후 배열을 표현 | |
enum | ◯ | 열거형. 숫자값 집합에 이름을 지정한 것이다. | |
any | ◯ | 타입 추론(type inference)할 수 없거나 타입 체크가 필요없는 변수에 사용. var 키워드로 선언한 변수와 같이 어떤 타입의 값이라도 할당 가능. | |
void | ◯ | 일반적으로 함수에서 반환값이 없을 경우 사용한다. | |
never | ◯ | 결코 발생하지 않는 값 |
다양한 타입을 사전 선언하는 방법은 다음과 같다.
1 | //boolean |
타입은 소문자, 대문자를 구별하므로 주의가 필요하다. 위에서 살펴본 바와 같이 TypeScript가 기본 제공하느 타입은 모두 소문다 이다.
1 | //string:원시 타입 문자열 |
string타입은 Ty[eScript가 기본으로 제공하는 원시 타입인 문자열 타입을 의미한다. 하지만 대문자로 시작하는 String 타입은 String 생성자 함수로 생성된 String 레퍼 객체 타입을 의미한다. 따라서 string 타입에 String 타입을 할당하면 에러가 발생한다. 하지만 String 타입에는string타입을 할당할 수 있다. 이처첨 객체의 유형도 타입이 될 수 있다.
1 | //Date타입 |
2. 정적 타이핑
C나 Java같은 언어는 변수를 선언할 때 변수에 할당할 값의 타입에 따라 사전에 타입을 명시적으로 선언하여야 하며 선언한 타입에 맞는 값을 할당해야한다. 이를 정적 타이핑이라한다.
자바스크립트는 동적 타입 언어 혹은 느슨한 타입 언어이다. 이것은 변수의 타입 선언없이 값이 할당되는 과정에서 동적으로 타입을 추론 한다는 의미이다. 동적 타입 언어는 타입 추론에 의해 변수의 타입이 결정된 후에도 같은 변수에 여러 타입의 값을 교차하여 할당할 수 있다. 이를 동적 타이핑 이라한다.
동적 타이핑은 사용하기 간편하지만 코드를 예측하ㄱ디 힘들어 예상치 못한 오류를 만들 가능성이 높다. 또한 IDE와 같은 도구가 변수나 매개변수,함수의 반환값의 타입을 알 수 없어 코드 어스크트 드으이 기능을 지원 할 수 없게 한다.
1 | var foo; |
TypeScript의 가장 독특한 특징인 정적 타이핑을 지원한다는 것이다. 정적 타입 언어는 타입을 명시적으로 선언하며, 타입이 결정된 후에는 타입을 변경할 수 없다. 잘못된 타입의 값이 할당 또는 반환되면 컴파일러는 이를 감지해 에러를 발생 시킨다.
1 | let foo:string,//문자열 타입 |
정적 타이핑은 변수는 물론 함수의 매개 변수와 반환값에도 사용할 수 있다.
1 | function add(x:number , y:number):number{ |
정적 타이핑과 동적 타이핑의 가장 큰 차이를 컴파일 시의 에러 검출고 런타임 시의 에러 검출로 볼 수 있는데 ,Java 와 같은 정적 타이핑 언어도 런타임에만 검출되는 에러가 존재하기 때문이다.
정적 타이핑의 장점은 코드 가독성,예측성,안정성의 향상 이라고 볼 수 있는데 이는 대규모 프로젝트에 적합하다.
3. 타입 추론
만약 타입 선언을 생력하면 값이 할당 도는 과정에서 동적으로 타입이 결정된다. 이를 타입 추론이라고 한다.
1 | let foo = 123 // foo는 number 타입 |
위 코드를 보면 변수 foo에 타입을 선언하지 않았으나 타입 추론에 의해 변수의 타입이 결정 된다. 동적타입 언어는 타입 추론에 의해 변수의 타입이 결정된 후에도 같은 변수에 여러 타입 값으 교차하여 할당 할 수 있다. 하지만 정적 타입 언어는 결정된 후에 타입을 변경 할 수 없다. TypeScript는 정적 타입 언어이므로 타입 추론으로 타입이 결정된 이후, 다른 타입의 값을 할당 하면 에러가 발생한다.
1 | let foo = 123 //foo는 number 타입 |
타입 선언을 생략하고 값을 할당하지 않아서 추론할 수 없으면 any 타입이 된다. any 타입의 변수는 자바스크립트의avr 키워드로 선언된 변수처럼 어떤 타입의 값도 재할당이 가능하다. 이는 TypeScript를 사용하는 장점을 없애기 때문에 사용하지 않는 편이 좋다.
1 | let foo ;// let foo: any와 동치 |