Heim > Web-Frontend > js-Tutorial > Hauptteil

Wie kann ich ein Array von Eigenschaftsschlüsseln aus einer TypeScript-Schnittstelle extrahieren?

Susan Sarandon
Freigeben: 2024-10-31 07:28:30
Original
631 Leute haben es durchsucht

How Can I Extract an Array of Property Keys from a TypeScript Interface?

Eigenschaftsschlüssel der TypeScript-Schnittstelle als Array

In der modernen TypeScript-Entwicklung stößt man häufig auf komplexe Schnittstellen, die die Struktur verschiedener Datenmodelle definieren. Oft besteht die Notwendigkeit, ein Array von Eigenschaftsnamen aus einer Schnittstelle zu extrahieren, um dynamische Operationen auszuführen oder abgeleitete Werte zu erstellen.

Beispiel für einen Anwendungsfall

Betrachten Sie die folgende Schnittstelle, die eine Datenbanktabelle darstellt:

<code class="typescript">export interface IMyTable {
  id: number;
  title: string;
  createdAt: Date;
  isDeleted: boolean;
}</code>
Nach dem Login kopieren

Wir möchten ein Array von Spaltennamen von dieser Schnittstelle erhalten:

<code class="typescript">const IMyTable = ["id", "title", "createdAt", "isDeleted"];</code>
Nach dem Login kopieren

Lösung mit benutzerdefiniertem Transformer

Seit TypeScript Version 2.3 (mit Fehlerkorrekturen in 2.4 ) bieten kundenspezifische Transformatoren eine elegante Lösung für dieses Problem. So können Sie die Bibliothek „ts-transformer-keys“ verwenden:

<code class="typescript">import { keys } from 'ts-transformer-keys';

interface Props {
  id: string;
  name: string;
  age: number;
}
const keysOfProps = keys<Props>();

console.log(keysOfProps); // ['id', 'name', 'age']</code>
Nach dem Login kopieren

Dieser Ansatz erfordert die Verwendung der TypeScript-Transformations-API, anstatt „tsc“ direkt auszuführen. Es ist wichtig zu beachten, dass sich kundenspezifische Transformatoren noch in einem frühen Stadium befinden und möglicherweise zusätzliche Konfigurationen erfordern.

Das obige ist der detaillierte Inhalt vonWie kann ich ein Array von Eigenschaftsschlüsseln aus einer TypeScript-Schnittstelle extrahieren?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage
Über uns Haftungsausschluss Sitemap
Chinesische PHP-Website:Online-PHP-Schulung für das Gemeinwohl,Helfen Sie PHP-Lernenden, sich schnell weiterzuentwickeln!