Heim >Web-Frontend >js-Tutorial >Wie kann ich ein Array von Eigenschaftsschlüsseln aus einer TypeScript-Schnittstelle extrahieren?

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

Susan Sarandon
Susan SarandonOriginal
2024-10-31 07:28:30786Durchsuche

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>

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

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

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>

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!

Stellungnahme:
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