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');
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; } };
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!