TypeScript - 함수의 명시적 this 타입

2023. 11. 21. 15:25· 📘 TypeScript
목차
  1. 함수의 명시적 this 타입

함수의 명시적 this 타입

interface User {
  name: string;
}
function greet(msg: string) {
  return `Hello ${this.name}, ${msg}`;
}

const baek = {
  name: "Baek",
  greet,
};
baek.greet("Good morning~"); // Hello Baek, Good morning~

const neo = {
  name: "Neo",
};
greet.call(neo, "Good afternoon~"); // Hello Neo, Good afternoon~
  • this에서 타입이 선언되어 있지 않기 때문에 암시적으로 any타입으로 지정된다
  • this가 최소한 "User interface의 구조는 가지고 있어야 한다"를 선언해야 한다
function greet(this: User, msg: string) {
  return `Hello ${this.name}, ${msg}`;
}
  • 위의 코드와 같이 greet() 함수를 바꿔면 에러가 발생하지 않는다
  • 따라서 함수 매개변수 안에서 this라는 이름으로 정의할 수 있다

'📘 TypeScript' 카테고리의 다른 글

TypeScript - 클래스의 접근 제어자  (0) 2023.11.21
TypeScript - 함수의 오버로딩  (0) 2023.11.21
TypeScript - 인터페이스(Interface)  (1) 2023.11.20
TypeScript - 타입 별칭(Alias)  (0) 2023.11.20
TypeScript - 타입 가드(Guard)  (0) 2023.11.20
  1. 함수의 명시적 this 타입
'📘 TypeScript' 카테고리의 다른 글
  • TypeScript - 클래스의 접근 제어자
  • TypeScript - 함수의 오버로딩
  • TypeScript - 인터페이스(Interface)
  • TypeScript - 타입 별칭(Alias)
zunwon
zunwon
zunwon
준원의 개발일지
zunwon
전체
오늘
어제
  • 분류 전체보기
    • 📒 JavaScript
    • 📘 TypeScript
    • React.js
    • 📗 Vue.js
    • 💻 알고리즘
      • 프로그래머스
      • 백준
    • ✏ 회고
      • 후기
    • 👨‍💻 TIL
    • 📋 오픈소스
    • 기타

블로그 메뉴

  • 홈
  • 태그
  • 방명록

공지사항

인기 글

태그

  • frontend
  • JavaScript
  • mil
  • 부스트캠프
  • 함수형자바스크립트
  • 코딩부트캠프
  • vercel
  • 프로그래머스 데브코스
  • 국비지원교육
  • 스나이퍼팩토리
  • next.js
  • 데브코스
  • githru
  • udemy
  • 프론트엔드
  • 프로그래머스
  • fontend
  • 회고
  • Vue.js
  • 알고리즘
  • TypeScript
  • 오픈소스컨트리뷰션
  • 미래내일일경험
  • 인사이드아웃
  • Vue
  • 자료구조
  • til
  • 프로젝트캠프
  • css
  • 함수형 자바스크립트

최근 댓글

최근 글

hELLO · Designed By 정상우.v4.2.1
zunwon
TypeScript - 함수의 명시적 this 타입
상단으로

티스토리툴바

단축키

내 블로그

내 블로그 - 관리자 홈 전환
Q
Q
새 글 쓰기
W
W

블로그 게시글

글 수정 (권한 있는 경우)
E
E
댓글 영역으로 이동
C
C

모든 영역

이 페이지의 URL 복사
S
S
맨 위로 이동
T
T
티스토리 홈 이동
H
H
단축키 안내
Shift + /
⇧ + /

* 단축키는 한글/영문 대소문자로 이용 가능하며, 티스토리 기본 도메인에서만 동작합니다.