Rumah >hujung hadapan web >tutorial js >Bagaimana untuk Memanggil Kaedah Statik dalam Kelas ES6: Pembina vs Nama Kelas?

Bagaimana untuk Memanggil Kaedah Statik dalam Kelas ES6: Pembina vs Nama Kelas?

DDD
DDDasal
2024-11-18 12:03:02665semak imbas

How to Call Static Methods in ES6 Classes: Constructor vs Class Name?

Cara Memanggil Kaedah Statik dalam Kelas ES6

Apabila berurusan dengan kaedah statik dalam kelas ES6, terdapat dua pendekatan utama untuk menggunakan kaedah tersebut. Pilihan antara kedua-duanya bergantung pada keperluan dan jangkaan khusus anda.

Menggunakan Pembina

Kaedah pertama melibatkan penggunaan fungsi pembina kelas. Sebagai contoh, dalam contoh berikut:

class SomeObject {
  constructor(n){
    this.n = n;
  }

  static print(n){
    console.log(n);
  }

  printN(){
    this.constructor.print(this.n);
  }
}

Untuk memanggil kaedah cetakan statik, anda boleh menggunakan this.constructor.print(n) dalam kaedah contoh, как показано в printN.

Menggunakan Nama Kelas

Pendekatan kedua ialah menggunakan kaedah statik secara terus melalui nama kelas. Meneruskan contoh sebelumnya:

SomeObject.print(n);

Pertimbangan Warisan

Apabila mengatasi kaedah statik dalam subkelas, kedua-dua pendekatan boleh mempunyai implikasi yang berbeza:

  • Menggunakan nama kelas merujuk kepada sifat statik kelas semasa dan menimpa jika ada. Ini serupa dengan pendekatan Java.
  • Menggunakan this.constructor merujuk kepada sifat statik kelas contoh semasa, termasuk sebarang kemungkinan penggantian. Ini serupa dengan tingkah laku Python.

Pendekatan Mana yang Perlu Dipilih?

Pendekatan yang paling sesuai bergantung pada tingkah laku yang anda inginkan. Jika anda mahukan kaedah statik yang sentiasa merujuk kepada kelas yang mereka miliki, gunakan nama kelas yang jelas. Jika anda lebih suka penghantaran dinamik, di mana kaedah statik yang diganti digunakan, gunakan this.constructor.

Atas ialah kandungan terperinci Bagaimana untuk Memanggil Kaedah Statik dalam Kelas ES6: Pembina vs Nama Kelas?. 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