Rumah  >  Artikel  >  hujung hadapan web  >  Bagaimanakah Saya Boleh Mengeluarkan Tatasusunan Kunci Harta daripada Antara Muka TypeScript?

Bagaimanakah Saya Boleh Mengeluarkan Tatasusunan Kunci Harta daripada Antara Muka TypeScript?

Susan Sarandon
Susan Sarandonasal
2024-10-31 07:28:30632semak imbas

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

Kunci Harta Antara Muka TypeScript sebagai Tatasusunan

Dalam pembangunan TypeScript moden, adalah perkara biasa untuk menghadapi antara muka kompleks yang mentakrifkan struktur pelbagai model data. Selalunya, terdapat keperluan untuk mengekstrak tatasusunan nama sifat daripada antara muka untuk melaksanakan operasi dinamik atau mencipta nilai terbitan.

Contoh Kes Penggunaan

Pertimbangkan antara muka berikut yang mewakili jadual pangkalan data:

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

Kami ingin mendapatkan tatasusunan nama lajur daripada antara muka ini:

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

Penyelesaian Menggunakan Transformer Tersuai

Sejak TypeScript versi 2.3 (dengan pembetulan pepijat dalam 2.4 ), transformer tersuai menawarkan penyelesaian yang elegan untuk masalah ini. Begini cara anda boleh menggunakan pustaka "ts-transformer-keys":

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

Pendekatan ini memerlukan penggunaan API transformasi TypeScript dan bukannya menjalankan "tsc" secara terus. Adalah penting untuk ambil perhatian bahawa pengubah tersuai masih di peringkat awal dan mungkin memerlukan konfigurasi tambahan.

Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Mengeluarkan Tatasusunan Kunci Harta daripada Antara Muka TypeScript?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn