티스토리 뷰
타입 스크립트 좋더라, 타입 스크립트 쓰세요. 런타임 에러가 확 줄어요..!라는 말을 종종 들으면서도 현재 회사에서 잡고 있는 프로젝트가 전부 JS로 되어 있는 것도 그렇고, 뭔가 JS도 잘 쓰고 있는 마당에 굳이...?라는 생각이 들어서 따로 쳐다보지를 않고 있었다.
이젠 리엑트로 프로젝트도 하고 있고, 조만간 RN으로도 하나 진행할 거 같아서 더는 미루지 말고 한번 사용이나 해보자! 라는 생각이 들어서 다뤄보려고 한다.
기본적인 내용부터 차근차근 공부해보자.
- 그래서 타입 스크립트가 뭐야?
타입스크립트(TypeScript)는 자바스크립트(JavaScript)를 기반으로 하는 언어로, 자바스크립트의 모든 기능을 포함하면서 타입 시스템을 추가해 준다는 것이 기본 콘셉트이다.
이로 인해 큰 규모의 애플리케이션 개발이나 복잡한 프로젝트에서 코드의 안정성과 유지 보수성을 향상할 수 있을 뿐 아니라, 아래 특징과 문법으로 인해 좀 더 객체 지향적인 프로그래밍이 가능하다는 점과 타입 지정으로 인한 런 타임 에러를 줄일 수 있는 등 다양한 장점을 가지고 있는 언어이다.
타입스크립트는 Microsoft에 의해 개발되었으며, 오픈 소스 프로젝트이다.
- 특징
- 정적 타이핑 지원: 변수, 매개변수, 객체 속성 등에 타입을 지정할 수 있어, 개발 과정에서 타입 체크를 통한 오류를 사전에 발견할 수 있다.
- 객체 지향 프로그래밍 지원: 클래스, 인터페이스 등 객체 지향 프로그래밍의 핵심적인 요소들을 사용할 수 있다.
- 최신 자바스크립트 기능 지원: ES6 이상의 최신 자바스크립트 문법과 기능을 사용할 수 있으며, 구버전 브라우저에서도 호환 가능한 자바스크립트 코드로 컴파일된다.
- 넓은 생태계와 도구 지원: 자동 완성, 코드 리팩토링, 타입 체크 등 다양한 개발 도구의 지원을 받을 수 있다.
- 기본 문법과 자료 구조
타입스크립트의 기본 문법과 자료 구조를 알아보자. 자바스크립트에 능숙하다면, 타입스크립트의 추가적인 타입 선언만 이해하면 된다.
변수 선언과 타입
let isDone: boolean = false;
let decimal: number = 6;
let color: string = "blue";
let list: number[] = [1, 2, 3];
let tuple: [string, number] = ["hello", 10]; // 튜플 타입
인터페이스
객체의 구조를 정의할 때 사용한다.
클래스와 비슷하게 속성과 메서드를 정의할 수 있지만, 인터페이스는 구현부가 없고, 타입 체킹 목적으로만 사용된다.
interface LabelledValue {
label: string;
}
function printLabel(labelledObj: LabelledValue) {
console.log(labelledObj.label);
}
let myObj = { size: 10, label: "size 10 object" };
printLabel(myObj);
클래스
타입스크립트에서 클래스도 자바스크립트와 비슷하지만, 타입과 접근 제한자(public, private 등)를 추가할 수 있다.
class Animal {
private name: string;
constructor(theName: string) {
this.name = theName;
}
move(distanceInMeters: number = 0) {
console.log(`${this.name} moved ${distanceInMeters}m.`);
}
}
let cat = new Animal("Cat");
cat.move(12);
함수
함수의 매개변수와 반환 값에 타입을 지정할 수 있다는 점을 제외하면 JS와 동일하다.
function add(x: number, y: number): number {
return x + y;
}
let myAdd = function(x: number, y: number): number { return x + y; };
제네릭
타입을 매개변수처럼 사용할 수 있어, 재사용 가능한 컴포넌트를 만들 때 유용하다.
function identity<T>(arg: T): T {
return arg;
}
let input = identity<string>("myString");
열거형
열거형은 관련된 상수들의 집합을 정의할 때 사용한다.
기본적으로 0부터 시작하지만, 수동으로 값을 할당하여 시작 값을 변경할 수 있다.
enum Color {Red, Green, Blue}
let c: Color = Color.Green;
any 타입
타입 체크를 원하지 않는 변수에 사용할 수 있는 타입이다. 기존 자바스크립트 코드를 타입스크립트로 점진적으로 이전하는 경우 유용할 수 있다.
let notSure: any = 4;
notSure = "maybe a string instead";
notSure = false; // okay, definitely a boolean
Void 타입
어떤 타입도 가지지 않는 빈 상태.
function warnUser(): void {
console.log("This is my warning message");
}
Null과 Undefined
타입스크립트에서 null과 undefined는 각각 null과 undefined만을 값으로 가질 수 있는 타입이다.
strictNullChecks 옵션이 true일 때, 모든 타입에 자동으로 포함되지 않으므로 명시적으로 사용해야 합니다.
let u: undefined = undefined;
let n: null = null;
네버 타입(Never)
절대 반환되지 않는 함수의 반환 타입으로 사용된다. 예를 들어, 함수가 예외를 발생시키거나 무한 루프에 빠지는 경우에 해당한다.
function error(message: string): never {
throw new Error(message);
}
유니언 타입(Union Types)
두 가지 이상의 타입 중 하나일 수 있는 값을 나타낸다. 예를 들어, string | number는 값이 문자열 또는 숫자일 수 있음을 의미한다.
function padLeft(value: string, padding: string | number) {
// ...
}
인터섹션 타입(Intersection Types)
여러 타입을 모두 만족하는 하나의 타입을 나타낸다. 예를 들어, Person & Serializable & Loggable은 Person, Serializable, Loggable의 모든 멤버를 가진 타입을 의미한다.
interface Person {
name: string;
}
interface Loggable {
log(name: string): void;
}
type PersonLoggable = Person & Loggable;
let john: PersonLoggable = {name: "John", log: (name) => console.log(name)};
타입 가드(Type Guards)
특정 범위 내에서 타입이 무엇인지를 보장하는 방법이다. 주로 조건문 내에서 사용된다.
function isNumber(val: string | number): val is number {
return typeof val === "number";
}
function doSomething(input: string | number) {
if (isNumber(input)) { // true
console.log(input.toFixed(2)); // 여기서 input은 number 타입으로 간주
} else { // false
console.log(input.charAt(0)); // 여기서 input은 string 타입으로 간주
}
}
옵셔널 속성(Optional Properties)
타입스크립트의 인터페이스나 타입에서, 특정 속성이 선택적으로 필요할 때 옵셔널 속성을 사용할 수 있다. 이는 객체를 생성할 때 해당 속성을 제공할 수도 있고, 생략할 수도 있음을 말한다. 옵셔널 속성은 속성 이름 끝에 ? 기호를 붙여서 표시한다.
interface Person {
name: string;
age?: number; // 옵셔널 속성
}
function greet(person: Person) {
console.log("Hello, " + person.name);
if (person.age !== undefined) {
console.log("You are " + person.age + " years old.");
} else {
console.log("Your age is unknown.");
}
}
greet({name: "Alice"});
greet({name: "Bob", age: 30});
Type Alias (타입 별칭)
타입 별칭은 특정 타입에 대한 새로운 이름을 정의할 때 사용된다. 기본적인 타입부터 복잡한 객체 구조, 심지어 유니언 타입이나 인터섹션 타입까지, 다양한 타입의 별칭을 생성할 수 있다.
type StringOrNumber = string | number;
type Student = {
name: StringOrNumber;
id: StringOrNumber;
};
function logStudent(student: Student) {
console.log(`Student Name: ${student.name}, ID: ${student.id}`);
}
logStudent({name: "Alice", id: 12345});
logStudent({name: "Bob", id: "s12345"});
확실히, 타입을 깐깐하게 지정하는 문법이 많아서 런타임 에러를 많이 줄일 수 있을 거 같긴 하다.
코드의 가독성이 좀 더 향상되고, 이로써 프로젝트의 안정성을 크게 올릴 수 있는 언어인 건 확실하다.
앞으로 자주 사용해서 친해져 봐야겠다...ㅋㅋ
'WEB > 자바스크립트' 카테고리의 다른 글
[JS] Array.reduce (0) | 2024.02.09 |
---|---|
[JS] async와 await (0) | 2024.01.08 |
[JS] Promise (0) | 2024.01.08 |
[js] 비구조화 할당 (1) | 2024.01.06 |
[Javascript] onkeydown 속성을 이용한 예제 (0) | 2021.05.14 |
- 정보보안기사 #실기 #정리
- Promise
- react-native
- 맛집
- Async
- 파니노구스토
- react
- 인천 구월동 이탈리안 맛집
- redux-thunk
- redux
- await
- 이탈리안 레스토랑
- javascript
- AsyncStorage
- 인천 구월동 맛집
- Total
- Today
- Yesterday