Rumah > hujung hadapan web > tutorial js > Bilakah untuk Mengelakkan Kelas Tanpa Nama Serta-merta?

Bilakah untuk Mengelakkan Kelas Tanpa Nama Serta-merta?

Barbara Streisand
Lepaskan: 2024-10-20 12:05:02
asal
589 orang telah melayarinya

When to Avoid Immediate Instantiation of Anonymous Classes?

Kesan Segera Kelas Tanpa Nama: Kisah Berhati-hati

Dalam ES6, adalah mungkin untuk mentakrifkan kelas tanpa nama dan membuat seketika mereka. Walaupun sintaks ini kelihatan menarik pada mulanya, adalah penting untuk memahami perangkapnya dan mengapa ia harus dielakkan secara amnya.

Untuk menjadikan kelas tanpa nama secara langsung, kami menggunakan sintaks berikut:

var entity = new class {
    constructor(name) { this.name = name; }
    getName() { return this.name; }
}('Foo');
Salin selepas log masuk

Di sebalik tabir, ini menghasilkan penciptaan fungsi pembina baharu dan objek prototaip untuk setiap instantiasi. Ini bermakna berbilang objek yang dibuat menggunakan kaedah ini tidak akan berkongsi apa-apa faedah daripada warisan kelas atau perhubungan prototaip.

Selain itu, pendekatan ini melemahkan percubaan untuk mencipta objek tunggal menggunakan kelas tanpa nama. Fungsi pembina masih boleh diakses dan digunakan untuk mencipta kejadian tambahan, menafikan gelagat tunggal yang dimaksudkan.

Berdasarkan kaveat ini, adalah amat disyorkan untuk mengelak daripada menggunakan kelas tanpa nama serta-merta. Literal objek yang lebih ringkas menawarkan alternatif yang lebih cekap dan mudah:

var entity = {
    name: 'Foo',
    getName() { return this.name; }
};
Salin selepas log masuk

Atas ialah kandungan terperinci Bilakah untuk Mengelakkan Kelas Tanpa Nama Serta-merta?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber:php
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