Rumah > hujung hadapan web > tutorial js > Antara muka dalam JavaScript Vanila dengan Kod VS IntelliSense

Antara muka dalam JavaScript Vanila dengan Kod VS IntelliSense

Susan Sarandon
Lepaskan: 2025-01-17 22:45:10
asal
800 orang telah melayarinya

TL;DR;

Simulasi antara muka JavaScript tulen, menggunakan fungsi analisis kod VS Code IntelliSense, boleh dipanggil kemahiran. Melalui gabungan pintar kilang objek dan fungsi kosong, gesaan kod seperti antara muka dan pemeriksaan jenis dilaksanakan, dan pengendali penggabungan nilai nol (??) digunakan untuk memudahkan kod. Dalam persekitaran pengeluaran, skrip binaan perlu digunakan untuk mengalih keluar kod antara muka yang tidak diperlukan.

Berikut ialah contoh antara muka JavaScript tulen yang bergantung pada analisis kod dalam editor kod seperti VS Code IntelliSense, jadi ia juga boleh dipanggil helah:

<code class="language-javascript">var interface = () => null;

var InterfaceOptions = () => ({
  name: '',
});
InterfaceOptions = interface;

// 使用示例
// =====

let opt = InterfaceOptions`` ?? {
  name: 'Bagel',
};

function createItem(options = InterfaceOptions``) {
  // ...
}

createItem(opt);</code>
Salin selepas log masuk
Salin selepas log masuk
Salin selepas log masuk

Berikut ialah contoh menamakan semula sifat dalam JavaScript tulen:

Interface in Vanilla JavaScript with VS Code IntelliSense

Anda mencipta kilang objek yang memulakan analisis kod sifat dan kemudian menggantikan objek dengan fungsi yang mengembalikan null. Ini membolehkan beberapa helah pengisytiharan menggunakan operator penggabungan nol (??) untuk memastikan kod anda kemas.

Interface in Vanilla JavaScript with VS Code IntelliSense

Interface in Vanilla JavaScript with VS Code IntelliSense

Ia juga berfungsi dengan tatasusunan! Lihat kod sampel dalam bahagian Trivia #4 di bawah.


Proses penemuan

  1. Saya harap VS Code IntelliSense akan meminta sifat pilihan createBox().

Interface in Vanilla JavaScript with VS Code IntelliSense


  1. Menggunakan parameter lalai berfungsi, tetapi saya ingin meletakkannya di tempat lain untuk mengurangkan kekacauan.

Interface in Vanilla JavaScript with VS Code IntelliSense


  1. Mengisytiharkan pilihan di luar fungsi menjana ralat kerana nilainya boleh diubah suai oleh sesiapa sahaja.

Interface in Vanilla JavaScript with VS Code IntelliSense


  1. Jadi mestilah kilang objek. Pada baris 5, saya menggunakan backticks dan bukannya kurungan untuk membezakan antara "antara muka" dan panggilan fungsi. Sebenarnya, demi artikel ini, saya hanya perlu menggunakan awalan nama unik untuk nama pembolehubah, seperti InterfaceBoxOptions atau sesuatu seperti itu, ok!

Interface in Vanilla JavaScript with VS Code IntelliSense


  1. Baiklah, ini berfungsi, tetapi bagaimana jika saya mengisytiharkan pilihan sebagai pembolehubahnya sendiri? Bagaimanakah saya memberitahu IntelliSense bahawa objek mempunyai sifat antara muka?

Interface in Vanilla JavaScript with VS Code IntelliSense

Interface in Vanilla JavaScript with VS Code IntelliSense


  1. Seperti yang anda ketahui, jika saya menetapkan antara muka kepada objek dahulu, IntelliSense menganggap sifat antara muka.

Interface in Vanilla JavaScript with VS Code IntelliSense


  1. Saya terkejut, ia masih berfungsi walaupun selepas menetapkan semula pembolehubah dengan objek baharu.

Interface in Vanilla JavaScript with VS Code IntelliSense


  1. Tetapi itu satu baris lagi. Melainkan ia adalah baris kod, saya tidak akan menerimanya! Tetapi bolehkah?

Interface in Vanilla JavaScript with VS Code IntelliSense


  1. Jawapannya ya, gunakan operator gabungan nol (??). Ini adalah satu-satunya cara yang saya temui. Walau bagaimanapun, untuk memperuntukkan objek baharu dan bukannya antara muka, saya perlu entah bagaimana membuat boxOptions mengembalikan null.

Interface in Vanilla JavaScript with VS Code IntelliSense


  1. Nasib baik - atau mungkin dengan reka bentuk - IntelliSense masih menggesa sifat awal antara muka walaupun selepas menugaskannya semula kepada fungsi yang mengembalikan nol (baris 5).

Itu sahaja, saya mendapat persediaan seperti antara muka yang berfungsi dalam JavaScript tulen. Mungkin sepatutnya menggunakan TypeScript dari awal, tetapi saya berada di barat liar.

Interface in Vanilla JavaScript with VS Code IntelliSense


Persekitaran pengeluaran

Untuk pengisytiharan objek, saya menulis skrip binaan yang menggantikan interfaceName ?? dengan rentetan kosong sebelum menghantarnya kepada Terser, kerana pemampat tidak akan menilai nilai nol yang dikembalikan oleh gabungan.

Sebelum:

<code class="language-javascript">var interface = () => null;

var InterfaceOptions = () => ({
  name: '',
});
InterfaceOptions = interface;

// 使用示例
// =====

let opt = InterfaceOptions`` ?? {
  name: 'Bagel',
};

function createItem(options = InterfaceOptions``) {
  // ...
}

createItem(opt);</code>
Salin selepas log masuk
Salin selepas log masuk
Salin selepas log masuk
Selepas

:

<code class="language-javascript">let opt = InterfaceOptions`` ?? {
  name: null,
};</code>
Salin selepas log masuk
Salin selepas log masuk

Jika anda tidak memadamkan bahagian antara muka, kod yang dimampatkan mungkin kelihatan seperti ini:

<code class="language-javascript">let opt = {
  name: null,
};</code>
Salin selepas log masuk
Salin selepas log masuk

Trivia

1. Gunakan var

untuk antara muka

Untuk antara muka, anda harus menggunakan var bukannya let atau const. Ini memastikan bahawa ia dialih keluar apabila menggunakan Terser untuk memampatkan di peringkat teratas.

<code class="language-javascript">let opt = (() => null)() ?? {
  name: null,
};</code>
Salin selepas log masuk
Salin selepas log masuk
<code class="language-javascript">var interface = () => null;

var InterfaceOptions = () => ({
  name: null,
});
InterfaceOptions = interface;</code>
Salin selepas log masuk

Isu Terser #572: Alih keluar pembolehubah yang hanya ditetapkan tetapi tidak pernah dibaca.


2. Alternatif antara muka kosong

Jika fungsi antara muka global tidak tersedia, contohnya jika anda menulis perpustakaan untuk orang lain, anda boleh melakukan ini:

<code class="language-javascript">// terser 选项
{
  toplevel: true,
  compress: true,
  // ...
}</code>
Salin selepas log masuk

3. Gunakan antara muka dalam antara muka

Jika anda masih belum memahaminya, begini caranya:

<code class="language-javascript">var interface = () => null;

var InterfaceOptions = () => ({
  name: '',
});
InterfaceOptions = interface;

// 使用示例
// =====

let opt = InterfaceOptions`` ?? {
  name: 'Bagel',
};

function createItem(options = InterfaceOptions``) {
  // ...
}

createItem(opt);</code>
Salin selepas log masuk
Salin selepas log masuk
Salin selepas log masuk

Interface in Vanilla JavaScript with VS Code IntelliSense

Tidak buruk, bukan?


4. Adakah ia berfungsi dengan tatasusunan?

Ya, tetapi anda perlu mencipta antara muka yang berasingan untuk tatasusunan agar IntelliSense berfungsi dengan baik. Saya akan mengatakan ia agak mengelirukan.

Interface in Vanilla JavaScript with VS Code IntelliSense

Contoh 1:

<code class="language-javascript">let opt = InterfaceOptions`` ?? {
  name: null,
};</code>
Salin selepas log masuk
Salin selepas log masuk

Tetapi ia mempunyai faedah. Sekarang anda tahu apa yang perlu ditambah pada tatasusunan!

Interface in Vanilla JavaScript with VS Code IntelliSense

Contoh 2:

<code class="language-javascript">let opt = {
  name: null,
};</code>
Salin selepas log masuk
Salin selepas log masuk

5. Bolehkah ia berfungsi secara rekursif?

Macam ini? Tidak, analisis kod terputus untuk objek khusus ini.

Interface in Vanilla JavaScript with VS Code IntelliSense

Tetapi anda boleh melakukan ini:

<code class="language-javascript">let opt = (() => null)() ?? {
  name: null,
};</code>
Salin selepas log masuk
Salin selepas log masuk

Semua imej telah dipelihara dan menggunakan format yang sama seperti teks asal. Memandangkan URL imej tidak boleh diproses secara langsung, saya mengekalkan laluan /uploads/... dalam teks asal. Sila pastikan laluan ini betul untuk persekitaran anda.

Atas ialah kandungan terperinci Antara muka dalam JavaScript Vanila dengan Kod VS IntelliSense. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber:php.cn
Kenyataan Laman Web ini
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
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan