Rumah hujung hadapan web Soal Jawab bahagian hadapan Adakah kelas es6 satu fungsi?

Adakah kelas es6 satu fungsi?

Apr 11, 2022 pm 02:37 PM
class es6 fungsi

kelas es6 ialah fungsi. Dalam es6, kelas (kelas) diperkenalkan sebagai templat untuk objek Kelas boleh ditakrifkan melalui kata kunci kelas Sintaks ialah "nama kelas {...}; intipati kelas ialah fungsi (fungsi), iaitu a gula sintaksis. Lapisan bawah dicipta melalui "pembina"

Adakah kelas es6 satu fungsi?

Persekitaran pengendalian tutorial ini: sistem Windows 7, ECMAScript versi 6, komputer Dell G3. 🎜>

kelas es6 ialah fungsi

Dalam ES6, kelas (kelas) diperkenalkan sebagai templat untuk objek, dan kelas boleh ditakrifkan melalui kata kunci kelas adalah fungsi.

Ia boleh dianggap sebagai gula sintaksis, dan lapisan bawahnya dicipta melalui

, menjadikan kaedah penulisan prototaip objek lebih jelas dan lebih seperti sintaks pengaturcaraan berorientasikan objek .

Kod di atas dilaksanakan menggunakan

ES6, iaitu kaedah pembina berikut data kelas. Jenisnya ialah fungsi, dan kelas itu sendiri menunjuk kepada pembina Apabila mentakrifkan kelas, tidak perlu menambah fungsi di hadapan, dan tidak perlu memisahkan kaedah dengan koma >构造函数Semua kaedah kelas ditakrifkan pada atribut prototaip kelas

function Person(name, age) {
    this.name = name;
    this.age = age;
}
Person.prototype.sayName = function() {
    return this.name;
}

const xiaoming = new Person('小明', 18);
console.log(xiaoming);
Salin selepas log masuk

Memanggil kaedah pada contoh kelas sebenarnya memanggil kaedah. pada prototaip >classContoh kelas

class Person {
    constructor(name, age) {
      this.name = name;
      this.age = age;
    }
  
    sayName() {
      return this.name;
    }
}
const xiaoming = new Person('小明', 18)
console.log(xiaoming);
// { name: '小明', age: 18 }

console.log((typeof Person));
// function
console.log(Person === Person.prototype.constructor);
// true
Salin selepas log masuk

Melainkan atribut contoh itu ditakrifkan secara eksplisit pada dirinya sendiri (iaitu, ditakrifkan pada objek ini), ia ditakrifkan pada prototaip (iaitu , ditakrifkan pada kelas).

Nota:

1 Tiada promosi berubah-ubah dalam kelas

Kerana ES6 tidak akan mempromosikan pengisytiharan kelas kepada ketua. daripada kod. Sebab peraturan ini adalah sama, anda mesti memastikan bahawa subkelas ditakrifkan selepas kelas induk
class A {
    constructor() {}
    toString() {}
    toValue() {}
}
// 等同于
function A () {
    // constructor
};
A.prototype.toString = function() {};
A.prototype.toValue = function() {};
Salin selepas log masuk

Kod di atas tidak akan melaporkan ralat, kerana apabila B mewarisi A, A sudah mempunyai definisi Walau bagaimanapun, jika terdapat promosi kelas, kod di atas tidak akan melaporkan ralat kerana kelas akan dinaikkan ke kepala kod, tetapi perintah let tidak dinaikkan pangkat, jadi apabila B mewarisi A, Foo belum ditakrifkan lagi
let a = new A();
a.constructor === A.prototype.constructor // true
Salin selepas log masuk

2. anda mesti berhati-hati. Sebaik sahaja kaedah ini digunakan secara bersendirian, ralat mungkin akan dilaporkan

Kelas boleh diluluskan

Kelas kod di atas mentakrifkan kelas Cat, yang mewarisi semua sifat dan kaedah dalam kelas Haiwan melalui kata kunci lanjutan. Tetapi oleh kerana tiada kod digunakan, kedua-dua kelas adalah sama, yang setara dengan menyalin kelas Haiwan. Seterusnya, kami menambah kod di dalam Cat.

Kata kunci super muncul dalam kedua-dua kaedah pembina dan kaedah toString Ia mewakili pembina kelas induk di sini dan digunakan untuk mencipta objek baharu ini bagi kelas induk.
new A(); // ReferenceError
class A {}
Salin selepas log masuk

Subkelas mesti memanggil kaedah super dalam kaedah pembina, jika tidak, ralat akan dilaporkan semasa mencipta tika baharu. Ini kerana objek ini milik subkelas sendiri mesti terlebih dahulu dibentuk oleh pembina kelas induk untuk mendapatkan atribut dan kaedah contoh yang sama seperti kelas induk, dan kemudian ia diproses dan atribut dan kaedah contoh subkelas itu sendiri ditambah. Jika kaedah super tidak dipanggil, subkelas tidak akan mendapat objek ini.

{
  let A = class {};
  class B extends A {}
}
Salin selepas log masuk

Cat mewarisi kelas induk Haiwan, tetapi pembinanya tidak memanggil kaedah super, menyebabkan kejadian baharu melaporkan ralat.

Jika subkelas tidak mentakrifkan kaedah pembina, kaedah ini akan ditambah secara lalai Kodnya adalah seperti berikut. Dalam erti kata lain, tidak kira sama ada ia ditakrifkan secara eksplisit atau tidak, mana-mana subkelas mempunyai kaedah pembina.

Perkara lain yang perlu diberi perhatian ialah pembina es5 boleh mengakses ini sebelum memanggil pembina induk, tetapi pembina es6 tidak boleh mengakses ini sebelum memanggil pembina induk (iaitu super).

Dalam kod di atas, kaedah pembina subkelas menggunakan kata kunci ini sebelum memanggil super, mengakibatkan ralat, bagaimanapun, adalah betul untuk meletakkannya selepas kaedah super.

class Animal {}
class Cat extends Animal { };
Salin selepas log masuk
Kaedah statik kelas induk juga akan diwarisi oleh subkelas.

class Cat extends Animal {
    constructor(name, age, color) {
        // 调用父类的constructor(name, age)
        super(name, age);
        this.color = color;
    }
    toString() {
        return this.color + ' ' + super.toString(); // 调用父类的toString()
    }
}
Salin selepas log masuk
[Cadangan berkaitan:

tutorial video javascript

,

bahagian hadapan web

]
class Animal { /* ... */ }

class Cat extends Animal {
  constructor() {
  }
}

let cp = new Cat();
// ReferenceError
Salin selepas log masuk

Atas ialah kandungan terperinci Adakah kelas es6 satu fungsi?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China 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

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

AI Hentai Generator

AI Hentai Generator

Menjana ai hentai secara percuma.

Artikel Panas

R.E.P.O. Kristal tenaga dijelaskan dan apa yang mereka lakukan (kristal kuning)
4 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Tetapan grafik terbaik
4 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Cara Memperbaiki Audio Jika anda tidak dapat mendengar sesiapa
4 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Arahan sembang dan cara menggunakannya
4 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Petua untuk mencipta fungsi baharu secara dinamik dalam fungsi golang Petua untuk mencipta fungsi baharu secara dinamik dalam fungsi golang Apr 25, 2024 pm 02:39 PM

Bahasa Go menyediakan dua teknologi penciptaan fungsi dinamik: penutupan dan refleksi. penutupan membenarkan akses kepada pembolehubah dalam skop penutupan, dan refleksi boleh mencipta fungsi baharu menggunakan fungsi FuncOf. Teknologi ini berguna dalam menyesuaikan penghala HTTP, melaksanakan sistem yang sangat boleh disesuaikan dan membina komponen boleh pasang.

Pertimbangan untuk susunan parameter dalam penamaan fungsi C++ Pertimbangan untuk susunan parameter dalam penamaan fungsi C++ Apr 24, 2024 pm 04:21 PM

Dalam penamaan fungsi C++, adalah penting untuk mempertimbangkan susunan parameter untuk meningkatkan kebolehbacaan, mengurangkan ralat dan memudahkan pemfaktoran semula. Konvensyen susunan parameter biasa termasuk: tindakan-objek, objek-tindakan, makna semantik dan pematuhan perpustakaan standard. Susunan optimum bergantung pada tujuan fungsi, jenis parameter, kemungkinan kekeliruan dan konvensyen bahasa.

Bagaimana untuk menulis fungsi yang cekap dan boleh diselenggara di Jawa? Bagaimana untuk menulis fungsi yang cekap dan boleh diselenggara di Jawa? Apr 24, 2024 am 11:33 AM

Kunci untuk menulis fungsi Java yang cekap dan boleh diselenggara ialah: pastikan ia mudah. Gunakan penamaan yang bermakna. Mengendalikan situasi khas. Gunakan keterlihatan yang sesuai.

Koleksi lengkap formula fungsi excel Koleksi lengkap formula fungsi excel May 07, 2024 pm 12:04 PM

1. Fungsi SUM digunakan untuk menjumlahkan nombor dalam lajur atau sekumpulan sel, contohnya: =SUM(A1:J10). 2. Fungsi AVERAGE digunakan untuk mengira purata nombor dalam lajur atau sekumpulan sel, contohnya: =AVERAGE(A1:A10). 3. Fungsi COUNT, digunakan untuk mengira bilangan nombor atau teks dalam lajur atau sekumpulan sel, contohnya: =COUNT(A1:A10) 4. Fungsi IF, digunakan untuk membuat pertimbangan logik berdasarkan syarat yang ditentukan dan mengembalikan hasil yang sepadan.

Perbandingan kelebihan dan kekurangan parameter lalai fungsi C++ dan parameter pembolehubah Perbandingan kelebihan dan kekurangan parameter lalai fungsi C++ dan parameter pembolehubah Apr 21, 2024 am 10:21 AM

Kelebihan parameter lalai dalam fungsi C++ termasuk memudahkan panggilan, meningkatkan kebolehbacaan dan mengelakkan ralat. Kelemahannya ialah fleksibiliti terhad dan sekatan penamaan. Kelebihan parameter variadic termasuk fleksibiliti tanpa had dan pengikatan dinamik. Kelemahan termasuk kerumitan yang lebih besar, penukaran jenis tersirat dan kesukaran dalam penyahpepijatan.

Apakah faedah fungsi C++ mengembalikan jenis rujukan? Apakah faedah fungsi C++ mengembalikan jenis rujukan? Apr 20, 2024 pm 09:12 PM

Faedah fungsi mengembalikan jenis rujukan dalam C++ termasuk: Peningkatan prestasi: Melewati rujukan mengelakkan penyalinan objek, sekali gus menjimatkan memori dan masa. Pengubahsuaian langsung: Pemanggil boleh mengubah suai secara langsung objek rujukan yang dikembalikan tanpa menugaskannya semula. Kesederhanaan kod: Lulus melalui rujukan memudahkan kod dan tidak memerlukan operasi penugasan tambahan.

Apakah perbezaan antara fungsi PHP tersuai dan fungsi yang telah ditetapkan? Apakah perbezaan antara fungsi PHP tersuai dan fungsi yang telah ditetapkan? Apr 22, 2024 pm 02:21 PM

Perbezaan antara fungsi PHP tersuai dan fungsi yang dipratentukan ialah: Skop: Fungsi tersuai terhad kepada skop definisinya, manakala fungsi yang dipratentukan boleh diakses di seluruh skrip. Cara mentakrifkan: Fungsi tersuai ditakrifkan menggunakan kata kunci fungsi, manakala fungsi yang dipratakrifkan ditakrifkan oleh kernel PHP. Lulus parameter: Fungsi tersuai menerima parameter, manakala fungsi yang dipratentukan mungkin tidak memerlukan parameter. Kebolehlanjutan: Fungsi tersuai boleh dibuat mengikut keperluan, manakala fungsi yang dipratentukan terbina dalam dan tidak boleh diubah suai.

Pengecualian Fungsi C++ Lanjutan: Pengendalian Ralat Tersuai Pengecualian Fungsi C++ Lanjutan: Pengendalian Ralat Tersuai May 01, 2024 pm 06:39 PM

Pengendalian pengecualian dalam C++ boleh dipertingkatkan melalui kelas pengecualian tersuai yang menyediakan mesej ralat khusus, maklumat kontekstual dan melaksanakan tindakan tersuai berdasarkan jenis ralat. Tentukan kelas pengecualian yang diwarisi daripada std::exception untuk memberikan maklumat ralat tertentu. Gunakan kata kunci lontaran untuk membuang pengecualian tersuai. Gunakan dynamic_cast dalam blok try-catch untuk menukar pengecualian yang ditangkap kepada jenis pengecualian tersuai. Dalam kes sebenar, fungsi open_file membuang pengecualian FileNotFoundException Menangkap dan mengendalikan pengecualian boleh memberikan mesej ralat yang lebih spesifik.

See all articles