> 웹 프론트엔드 > JS 튜토리얼 > TypeScript의 인터페이스에서 런타임 유형 검사를 수행하는 방법은 무엇입니까?

TypeScript의 인터페이스에서 런타임 유형 검사를 수행하는 방법은 무엇입니까?

DDD
풀어 주다: 2024-11-24 18:17:11
원래의
343명이 탐색했습니다.

How to Perform Runtime Type Checks on Interfaces in TypeScript?

TypeScript의 인터페이스 유형 확인: 런타임 확인을 위한 여정

TypeScript는 코드 정확성을 보장하기 위한 유형 확인 기능을 제공합니다. 그러나 인터페이스를 다룰 때 변수가 런타임에 인터페이스를 구현하는지 확인하는 것은 어려울 수 있습니다.

다음 코드를 고려하세요.

interface A {
    member: string;
}

var a: any = { member: "foobar" };

if (a instanceof A) alert(a.member);
로그인 후 복사

이 코드는 컴파일 중에 다음과 같은 오류를 발생시킵니다. "A라는 이름은 현재 범위에 존재하지 않습니다." 인터페이스 선언에도 불구하고 TypeScript는 JavaScript의 인터페이스 표현 부족으로 인해 런타임 시 문제에 직면합니다.

TypeScript 사용자 정의 유형 가드

이러한 제한을 극복하기 위해 TypeScript는 사용자 정의 유형 가드를 도입합니다. 유형 가드를 사용하면 인스턴스에 의존하지 않고 인터페이스를 확인할 수 있습니다. 예는 다음과 같습니다.

interface A {
    member: string;
}

function instanceOfA(object: any): object is A {
    return 'member' in object;
}

var a: any = { member: "foobar" };

if (instanceOfA(a)) {
    alert(a.member);
}
로그인 후 복사

이 코드는 가 instanceOfA 유형 가드를 사용하여 A 인터페이스를 구현하는지 성공적으로 확인합니다.

복잡한 인터페이스 구현 처리

인터페이스에 여러 멤버가 있는 시나리오의 경우 판별자 접근 방식이 유용할 수 있습니다. 간단한 예는 다음과 같습니다.

interface A {
    discriminator: 'I-AM-A';
    member: string;
}

function instanceOfA(object: any): object is A {
    return object.discriminator === 'I-AM-A';
}

var a: any = { discriminator: 'I-AM-A', member: "foobar" };

if (instanceOfA(a)) {
    alert(a.member);
}
로그인 후 복사

이 경우 판별자 속성은 A 인터페이스를 구현하는 객체에 대한 고유 식별자 역할을 합니다.

결론

TypeScript의 사용자 정의 유형 가드와 판별자 접근 방식을 통해 개발자는 인터페이스에서 런타임 유형 검사를 수행하여 코드 정확성을 보장하고 잠재적인 가능성을 예방할 수 있습니다. 오류가 발생했습니다.

위 내용은 TypeScript의 인터페이스에서 런타임 유형 검사를 수행하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿