Rumah >hujung hadapan web >tutorial js >Bagaimanakah Kelas ES6 boleh Digunakan untuk Memanjangkan Fungsi dan Mengakses Data Contoh?

Bagaimanakah Kelas ES6 boleh Digunakan untuk Memanjangkan Fungsi dan Mengakses Data Contoh?

Linda Hamilton
Linda Hamiltonasal
2024-10-21 06:09:30251semak imbas

How can ES6 Classes be Used to Extend Functions and Access Instance Data?

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:

  1. Pengekodan keras: Paksa panggilan super untuk mengharapkan rentetan kod yang mengandungi data tika.
class Smth extends Function {
  constructor(x) {
    super("return " + JSON.stringify(x) + ";");
  }
}
  1. Menggunakan Penutupan: Kembalikan fungsi penutupan yang mengakses pembolehubah contoh.
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!

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