[TypeScript] 클래스와 인터페이스
·
언어/JS & TS
JS, TS와 OOPJS의 변수와 함수는 모두 객체다. 이는 JS의 모든 객체가 프로토타입(prototype)이기 때문이다. 프로토타입 언어란 모든 객체가 최소한 하나 이상의 다른 객체(그들의 프로토타입으로부터) 상속을 받는 언어이다. 이때 상속되는 정보를 제공하는 객체를 프로토타입이라고 한다. 따라서, JS로 객체지향 코드를 구성하려면 애로 사항이 많았다. 이 문제를 해결하기 위해 ES6(ECMAScript 2015)부터는 클래스 문법을 추가하였고, 보다 자바스럽게 클래스를 구성할 수 있게되었다.   클래스TS의 클래스 문법은 JS와 크게 다르지 않다.다만, JAVA의 객체 지향 문법을 끌어와서 쓰다보니 JS에는 없는 것까지 사용하면서 몇몇 제약이 생긴다.  JS의 클래스 선언 방식class Stude..
[TypeScript] 함수 표현식 & Call∙Constructor Signature
·
언어/JS & TS
개요JS와 비교하여 TS에서 함수 타입을 정의하는 방법, 이와 관련한 호출 시그니처와 생성자 시그니처에 대해 정리한다. 함수 타입 정의가장 기본적으로 함수를 정의하는 방법은 다음 내용과 같다. 1. 함수의 반환값 타입은 추론되기 때문에 생략 가능하다.function add(a: number, b: number): number { return a+b;}   2. 화살표 함수도 반환값 타입은 생략 가능하다.const add = (a: number, b:number) => a+b;   3. type 별칭을 통해서 함수 타입을 정의할 수 있다.type GreetFunction = (a: string) => void;function greeter(fn: GreetFunction) { // ....}  이와 관련해..
[TypeScript] Narrowing | Type Assertions & Type Guards
·
언어/JS & TS
Narrowing TS에서 타입 검사를 통해 조건을 좁혀서 특정 행동을 하는 것을 통칭하여 Narrowing이라고 한다. Type Assertions 타입 단언은 말 그대로 타입을 단언적으로 명시해주는 것이다. 타입 스크립트가 타입 추론을 통해 판단할 수 있는 타입의 범주를 넘어서는 경우, 더이상 추론하지 않도록 직접 지시한다. 💡타입 단언은 C나 JAVA의 타입 형변환과는 다른 개념이다. 형변환은 실제로 데이터 자료를 변환시키지만, 타입 단언은 실제 데이터를 바꾸는 것이 아니라 타입 정보를 명확히 남기는 것이므로 오직 컴파일 과정의 타입체킹에만 사용된다. (코드 자체에 에러는 발생하지 않지만 실행하다보면 오류를 일으키기도 한다.) 타입 단언 선언 방법 document.getElementById를 id가..
[TypeScript] TS 기본 지식 | 정적타입언어, tsc, 타입
·
언어/JS & TS
개요 TypeScript 언어를 공부하는 과정을 정리한다. microsoft에서 제공하는 자료를 토대로 진행한다. TypeScript Basics Each and every value in JavaScript has a set of behaviors you can observe from running different operations. That sounds abstract, but as a quick example, consider some operations we might run on a variable named foo. If we break this down, the first runna microsoft.github.io 정적 타입이란? 동적 타입 언어와 정적 타입 언어 (정적 타입 검사(S..
sebinChu
'typescript' 태그의 글 목록