„Wenn ein Arbeiter seine Arbeit gut machen will, muss er zuerst seine Werkzeuge schärfen.“ – Konfuzius, „Die Gespräche des Konfuzius. Lu Linggong“
Titelseite > Programmierung > Wie führe ich Laufzeit-Schnittstellentypprüfungen in TypeScript durch?

Wie führe ich Laufzeit-Schnittstellentypprüfungen in TypeScript durch?

Veröffentlicht am 23.12.2024
Durchsuche:103

How to Perform Runtime Interface Type Checks in TypeScript?

Schnittstellentypprüfung in TypeScript

In TypeScript können Sie auf ein Szenario stoßen, in dem es entscheidend ist, die Konformität eines Objekts mit einer vordefinierten Schnittstelle zur Laufzeit zu bestimmen . Während Klassentypprüfungen mithilfe des Schlüsselworts „instanceof“ unkompliziert sind, stellt die Anwendung auf Schnittstellen eine Herausforderung dar.

Herkömmliche Ansätze, wie die Verwendung des Operators „instanceof“, erweisen sich als ineffektiv, da Schnittstellen in kompiliertem JavaScript nicht als eindeutige Typen dargestellt werden. Stattdessen bieten benutzerdefinierte Typwächter eine Lösung:

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);
}

Dieser Ansatz ermöglicht eine Laufzeitüberprüfung der Schnittstellenkonformität, ohne dass das Schlüsselwort „instanceof“ erforderlich ist.

In Situationen, in denen mehrere Mitglieder überprüft werden müssen, kann eine Diskriminatoreigenschaft eingeführt werden. Dieser Ansatz erfordert die Verwaltung Ihrer eigenen Diskriminatoren und die Sicherstellung der Einzigartigkeit, um Konflikte zu vermeiden:

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);
}

Durch den Einsatz benutzerdefinierter Typwächter oder Diskriminatoren können Sie Schnittstellentypprüfungen zur Laufzeit effektiv durchführen und so die Robustheit Ihrer TypeScript-Anwendungen verbessern.

Neuestes Tutorial Mehr>

Haftungsausschluss: Alle bereitgestellten Ressourcen stammen teilweise aus dem Internet. Wenn eine Verletzung Ihres Urheberrechts oder anderer Rechte und Interessen vorliegt, erläutern Sie bitte die detaillierten Gründe und legen Sie einen Nachweis des Urheberrechts oder Ihrer Rechte und Interessen vor und senden Sie ihn dann an die E-Mail-Adresse: [email protected] Wir werden die Angelegenheit so schnell wie möglich für Sie erledigen.

Copyright© 2022 湘ICP备2022001581号-3