MEAN STACK/Angular

타입스크립트(Type Script) 데이터 타입, 예제

minwoohi 2018. 9. 12. 09:31

컴파일 언어인터프리터 언어 차이점 컴파일 언어는 타입을 가지고 있다.
인터프리트 언어의 경우 개발할  타입체킹(Type Checking) 없기 때문에 코드 작성  에러나면 디버깅이 굉장히 어렵다.
SPA 경우  페이지에서 서비스를 수행한다따라서 코드 작성  루틴  에러가 난다면 처음부터 다시 해야 하는 경우가 빈번하다따라서 코드 작성시 에러를 줄이도록 하는 노력이 필요했고이를 충족시키기 위한 언어가 타입스크립트(TypeScript)이다자바스크립트를 발전시킨 언어로 자바스크립트에서 타입을 구분할 수 있도록 되었다는 점이 가장 큰 차이점중 하나다. 코드 작성시 에러를 파악하고 디버깅이 용이하다는 점이 자바스크립트와 비교할 때 두드러지는 강점이다. 자바스크립트에서 파생된 언어이기 때문에 자바스크립트의 모든 문법 또한 사용 가능하다.

등장 배경
빅데이터 처리시 객체지향만으로는 속도 한계가 보였음(반복문 등 ng 구문들도 같은 반복문같은데 성능에 차이가 있다는 점은 아직 와닿지 않는다.
속도 빠른 함수 지향 패러다임 재조명 But 반복문을 대체하는 것이 굉장히 난해하다.(맵리듀스를 비롯)


타입스크립트 홈페이지 접속한다.

http://www.typescriptlang.org/


다운로드 클릭하면

Npm 명령어를 통해 설치하라고 한다. 이는 Node 필요하다는 것이다.(npm이 Node Package Manager의 약어

vs code 임의의 폴더 생성 후 터미널에 명령어 입력한다. 
npm install -g typescript 
(Global) 옵션 통해 전역 설치.

타입스크립트와 Angular 함께 사용하기 위해 타이핑스(Typings) 필요
타이핑스 : Angular에서 필요한 TypeScript 설정 객체

폴더에서 let.ts 파일 생성 후 다음과 같이 코드 작성.
기존 자바스크립트 코드이다.
vs code의 경우 컴파일시 직접 경로로 이동해 명령어 입력해야 한다.
기본적으로 cd Tab, 이용해 이동 가능
cd Tab : 파일 이동 명령어로 탭을 누르면 해당 폴더의 하위 폴더 및 파일명이 자동입력된다. 
상위로 이동하고 싶다면 cd ../ 입력

tsc 명령어 통해 컴파일. (typescript compile 약어)
node 파일명 입력하면 결과를 확인할 수 있다.

Type Script 문법 코드.




let num: number = 10;
let str: string = "10";

let bool = true;
//bool = 10;

let nameStr: string|number = "name";
nameStr = 10;

let ageVal: any = "";
ageVal = 10;
ageVal = true;
ageVal = function(){};

Ecma6의 문법을 사용하도록 한다. 변수 : let / 객체 : const
let num: number = 10; 
num 변수에 number 이외의 리터럴 값을 입력하면 컴파일 에러가 발생하게 된다.

다음과 같이 타입을 지정하지 않는 경우 처음 할당하는 리터럴 값에 따라 타입이 결정된다.
let bool = true; 
bool 은 boolean의 변수로 정해진것이다.


이후 "bool = 10;" 과 같이다른 타입의 변수를 할당할 수 없다.

다음과 같이 |를 이용해 여러 타입의 변수를 할당할 수도 있다.
let nameStr: string|number = "name"; 

nameStr = 10; 

any를 이용하면 자바스크립트의 var처럼 모든 타입의 리터럴 값을 할당 가능하다.
let ageVal: any = ""; 
ageVal = 10; 
ageVal = true; 
ageVal = function(){};

클래스 : ECMA Script 6(2015)에서 포함. Js 스펙이다.





export class Car{
    // private는 TypeScript부터 지원
    private tiresCount: number;
    private handleType: string;

    /**
     * 생성자
     */
    constructor(){

    }

    getTiresCount(): number{
        return this.tiresCount;
    }

    setTiresCount(tiresCount: number): void{
        this.tiresCount = tiresCount;
    }
    getHandleType(): string{
        return this.handleType;
    }

    setHandleType(handleType: string): void {
        this.handleType = handleType;
    }

}

 const car: Car = new Car();
    car.setHandleType("VOLVO");
    car.setTiresCount(4);

    console.log(car.getHandleType());
    console.log(car.getTiresCount());

Export public 같은 역할. 다른 패키지에서 접근가능하도록 하는 접근지정자. 없다면 private으로 된다. 다음과 같이 클래스, 생성자, Getter, Setter를 작성할 수 있다.


function getAddResult(): number{
    return 10 + 50;
}

function getAddResultTwoNum(one: number, two: number):number{
    return one + two;
}

let result: number = getAddResult();
let result2: number = getAddResultTwoNum(30, 2);

console.log(result);
console.log(result2);

let func: () => number = function(): number{return 10;};

함수 또한 다음과 같이 타입을 지정할 수 있다.
마지막 줄에서 함수 변수의 리턴 타입을 지정할 때 => 를 사용하는 것이 특이사항.