Home > Web Front-end > JS Tutorial > How to Perform Runtime Interface Type Checks in TypeScript?

How to Perform Runtime Interface Type Checks in TypeScript?

Patricia Arquette
Release: 2024-12-15 03:33:12
Original
687 people have browsed it

How to Perform Runtime Interface Type Checks in TypeScript?

Interface Type Check in TypeScript

Within TypeScript, you may encounter a scenario where determining an object's compliance with a predefined interface at runtime is crucial. While class type checks leveraging the instanceof keyword are straightforward, applying it to interfaces presents a challenge.

Traditional approaches, such as relying on the instanceof operator, prove ineffective since interfaces lack representation as distinct types in compiled JavaScript. Instead, custom type guards offer a solution:

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);
}
Copy after login

This approach allows runtime verification of interface compliance without the need for the instanceof keyword.

In situations where multiple members must be checked, a discriminator property can be introduced. This approach requires managing your own discriminators and ensuring uniqueness to avoid conflicts:

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);
}
Copy after login

By employing custom type guards or discriminators, you can effectively perform interface type checks at runtime, enhancing the robustness of your TypeScript applications.

The above is the detailed content of How to Perform Runtime Interface Type Checks in TypeScript?. For more information, please follow other related articles on the PHP Chinese website!

source:php.cn
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Latest Articles by Author
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template