Memperluas Fungsi dengan Kelas ES6
Dalam ES6, objek khas boleh dilanjutkan, membenarkan pewarisan daripada objek Fungsi. Walaupun ada kemungkinan untuk memanggil objek tersebut sebagai fungsi, melaksanakan logik untuk panggilan ini boleh menjadi mencabar.
Melalukan Data Contoh kepada Panggilan Fungsi
Apabila memanggil kelas sebagai fungsi , ini merujuk kepada objek tetingkap. Untuk mengakses data tika, dua pendekatan tersedia:
class Smth extends Function { constructor(x) { super("return " + JSON.stringify(x) + ";"); } }
class Smth extends Function { constructor(x) { function smth() { return x; }; Object.setPrototypeOf(smth, Smth.prototype); return smth; } }
Mengabstraksi Sambungan Fungsi
Pendekatan yang lebih umum ialah mencipta kelas ExtensibleFunction yang mengendalikan sambungan:
class ExtensibleFunction extends Function { constructor(f) { return Object.setPrototypeOf(f, new.target.prototype); } }
Kelas ini kemudiannya boleh digunakan untuk melanjutkan kelas tertentu:
class Smth extends ExtensibleFunction { constructor(x) { super(() => { return x; }); // closure } }
Ringkasnya, melanjutkan Fungsi dengan kelas ES6 membolehkan untuk mewarisi tingkah laku fungsi sambil menyesuaikan logik panggilan. Pendekatan yang berbeza boleh digunakan untuk menyediakan akses kepada data contoh apabila memanggil fungsi lanjutan.
Atas ialah kandungan terperinci Bagaimanakah Kelas ES6 boleh Digunakan untuk Memanjangkan Fungsi dan Mengakses Data Contoh?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!