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

Linda Hamilton
Lepaskan: 2024-10-21 06:09:30
asal
215 orang telah melayarinya

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) + ";");
  }
}
Salin selepas log masuk
  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;
  }
}
Salin selepas log masuk

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);
  }
}
Salin selepas log masuk

Kelas ini kemudiannya boleh digunakan untuk melanjutkan kelas tertentu:

class Smth extends ExtensibleFunction {
  constructor(x) {
    super(() => { return x; }); // closure
  }
}
Salin selepas log masuk

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!

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