안녕하세요 동기 여러분! 오늘은 Optional Type Members에 대해 알아봅시다! Optional Type Members 예전에 Optional Parameters를 포스팅할 때 이미 한 번 알아본 적이 있는 내용입니다. 바로!!! 물음표를 사용하는 것입니다!!! 스타크래프트의 유닛을 보면 이름, 체력, 공격력, 방어력은 반드시 가지고 있습니다. 하지만 마나나 스킬이 없는 경우는 있죠. (물론... 공격력이 없는 경우도 있는데 제외하겠습니다... ㅈㅅ 코드 다 쓰고 나니까 생각나서 ㅠㅠ ㅋㅋㅋ) 그래서 코드를 아래와 같이 써주었습니다. interface StarcraftUnit { name: string; hp: number; mp?: number; skill?: string; damage: n..
안녕하세요 동기 여러분! 오늘은 Index Signature에 대해 알아봅시다! Index Signatures 객체를 유형을 알아낼 때 가끔씩 객체의 프로퍼티의 이름을 알 수가 없는 경우가 있습니다. 특히, 우리가 밖의 데이터 source/API의 정보를 받아 올 때 그런데요, 아래의 코드를 보도록 합시다. { '오늘의': 2; '점심은': 53; '초밥이다': 12; '기분저아': 1; } 위 코드를 보면 '프로퍼티가 string이네, 값은 number구나!'라는 기본적인 사실은 알 수 있지만 프로퍼티의 이름을 알 수가 없습니다. 이런 경우, Index Signature를 활용하여 개발자들이 객체의 자세한 정보를 빠르게 알아차릴 수 있게 도와줍니다. Index Signature 생김새 interface..
안녕하세요 동기 여러분! 저번 시간에 알아본 Composed Interface는 뭔가 공통이 되는 부분을 프로퍼티의 값으로 당겨와서 인터페이스를 작성했는데 오늘은 알아볼 Extending Interface는 인터페이스와 다른 인터페이스를 합치는 방법에 대해 알아보겠습니다. 뭔가 합집합 같은 느낌이에요. Extending Interfaces extend를 영어사전에 찾아보면 '연장하다'라는 뜻이 있습니다. '오호 그럼 인터페이스를 연장하겠군!'이라 생각하며 아래의 코드를 봅시다. interface Baegopa { iWant: string; } interface NadoBaegopa { weWant: string; beverage: () => void; } const letsEat: Baegopa = { ..
안녕하세요 동기 여러분! 오늘은 중첩된 인터페이스 프로퍼티의 값을 다른 인터페이스에 옮겨 담아 코드를 깔끔하게 만드는 방법에 대해 알아봅시다! Composed Types 아래의 코드를 봅시당! interface Color { red: { blue: string; green: string; yellow: { orange:number; } } } 아주 복잡해 보이는 중첩된 인터페이스입니다. 컴포즈드 타입(Composed Type)을 이용하면 코드를 깔끔하게 정리를 할 수가 있습니다. interface Color { red: Red; } interface Red { blue: string; green: string; yellow: Yellow; } interface Yellow { orange:number; ..
안녕하세요 동기 여러분! 오늘은 중첩 메서드의 인터페이스를 작성하는 방법에 대해 알아봅시다! Deep Types 아래의 코드를 봅시다. interface Characters { heros: { blackWidow: { alias: string; gender: string; height: number; } } } class Marvel implements Characters{ heros = { blackWidow: { alias: 'Black Widow', gender: 'female', height: 170 } } } const infoBW = new Marvel(); console.log(infoBW.heros); 인터페이스 Characters라는 인터페이스를 만들고 hero안에 blackWidow안에..
안녕하세요 동기 여러분! 오늘은 interface 키워드를 class에 적용하는 놀라운 일을 알아봅시다. Interfaces and Classes interface는 class(클래스)와 object(객체)에 타입을 설정하기 위한 아주 좋은 방법입니다. 생김새 interface 타입명 { 메서드명: (매개 변수: 타입) => 타입; } class 클래스명 implements 타입명 { 메서드명(매개 변수: 타입) { 메서드 내용; } } 해봅시다! 원을 CAD와 USD로 바꾸어 주는 클래스를 만들고 interface로 타입을 설정해보고 실행도 해봅시다. interface KoreanMoney{ caculatingCAD: (won: number) => void; } class WonToCADnUSD imp..
안녕하세요 동기 여러분! 오늘은 객체 타입 심화의 첫 번째 시간으로 Interface를 알아보고 Type과의 차이점은 무엇인지 알아보도록 하겠습니다. Interfaces and Types 아래의 type과 interface의 코드를 보도록 합시다. type StarcraftUnit = { name: string; HP: number; } const marine: StarcraftUnit = // 내용 interface StarcraftUnit { name: string; HP: number; } const marine: StarcraftUnit = // 내용 두 코드를 봤을 때 가장 눈에 띄는 차이점은 키워드(type, interface)가 다르다는 것과 type에는 있는 =(equal) 표시가 inte..
안녕하세요 동기 여러분! 오늘은 타입 좁히기 마지막 시간으로 저저번 시간에 if문을 두 개 쓰다가 저번 시간에는 else로 바꿔서 코드를 깔끔하게 다듬어 줬는데 이번 시간에는 그 else도 없애버리겠습니다 ㅎㅎ Narrowing After a Type Guard 타입스크립트가 타입을 좁히는 방법이 조건문을 사용하여 변수가 특정한 타입인지 아닌지를 확인하고 이것을 우리가 타입 가드(Type guard)라고 부른다고 알아봤었습니다. 오늘의 제목인 Narrowing After a Type Guard(타입 가드 후 좁히기)인데요 → 아니 타입 가드를 했는데 그 후에 또 타입을 좁힌다고??? 이게 머선소리고? 아래는 세 번째 우려먹고 있는 코드입니다. 저번 시간에는 아래와 같이 함수에 if문과 else를 써준 깔..
안녕하세요 동기 여러분! 헤헤 엠블럼을 하나 만들어 봤습니다ㅋㅋㅋ 오늘은 타입 좁히기의 세 번째 시간으로 if문에 else도 사용하여 타입을 좁혀 보도록 하겠습니다!!! Narrowing with else 저번 시간에 이런 코드를 만들었었습니다. type Bionic = { run: () => string; } type Mechanic = { drive: () => string; } const marine = { run: () => '자! 가자, 가자!, 좋았어!, 한바탕 놀아볼까!' } const siegeTank = { drive: () => '이동!, 전진 앞으로!, 기꺼이!' } function move(unit: Bionic | Mechanic) { if('run' in unit) { retur..
안녕하세요 동기 여러분! 오늘은 타입 좁히기의 두 번째 시간으로 in 연산자를 이용하여 프로퍼티(Property)가 객체(Object)나 프로토타입 체인(Prototype Chain)에 존재하는지 확인하는 방법에 대해 알아봅시다! Using in with Type Guards 여기서 in은 '~안에'라고 해석하면 코드를 읽기가 편해집니다. 사용방법 1. 타입 선언해주기 스타크래프트 테란의 바이오닉 체제와 메카닉 체제를 이용하여 타입을 선언해주겠습니다. 타입 바이오닉과 타입 메카닉를 타입 에일리어스로 선언해보겠습니다. type Bionic = { run: () => string; } type Mechanic = { drive: () => string; } 2. 타입에 맞는 변수 설정하기 바이오닉의 대표적인..
- Total
- Today
- Yesterday
- html
- 메서드
- 파이썬
- CSS
- Margin
- Object
- method
- function
- html table
- 함수
- 타입 좁히기
- 반복문
- javascript
- 자바스크립트
- css position
- CSS 포지션
- if문
- Type
- 객체
- Python
- Typescript
- padding
- 타입스크립트
- 실수
- 동기코딩
- em
- 프로그래머스
- HTML 기본
- Array
- for문
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |