Rumah hujung hadapan web tutorial js Analisis contoh penggunaan warisan rantai prototaip javascript_kemahiran javascript

Analisis contoh penggunaan warisan rantai prototaip javascript_kemahiran javascript

May 16, 2016 pm 04:17 PM
javascript rantai prototaip penggunaan mewarisi

Artikel ini menganalisis penggunaan pewarisan rantaian prototaip JavaScript dengan contoh. Kongsikan dengan semua orang untuk rujukan anda. Analisis khusus adalah seperti berikut:

Salin kod Kod adalah seperti berikut:
function Shape(){
this.name = 'shape';
this.toString = function(){
Kembalikan nama ini.
}
}

fungsi TwoDShape(){
this.name = 'Bentuk 2D'; }
fungsi Segitiga(sisi, tinggi){
this.name = 'Segitiga';
this.side = sebelah; ini.tinggi = tinggi; this.getArea = function(){
Kembalikan ini.sisi*ini.tinggi/2; };
}

/* pusaka */
TwoDShape.prototype = new Shape(); Triangle.prototype = TwoDShape();


Apabila kita menulis semula sepenuhnya sifat prototaip objek, kadangkala ia akan memberi kesan negatif tertentu pada sifat pembina objek.
Oleh itu, selepas kami melengkapkan tetapan perhubungan warisan yang berkaitan, adalah satu tabiat yang sangat baik untuk menetapkan semula atribut const bagi objek ini dengan sewajarnya. Seperti yang ditunjukkan di bawah:


Salin kod


Salin kod


Kod adalah seperti berikut:function Shape(){} Shape.prototype.name = 'shape'; Shape.prototype.toString = function(){ kembalikan this.name;
}

fungsi TwoDShape(){}

TwoDShape.prototype = new Shape(); TwoDShape.prototype.constructor = TwoDShape

TwoDShape.prototype.name = '2d shape';

fungsi Segitiga(sisi, tinggi){
this.side = sebelah; ini.tinggi = tinggi; }

Triangle.prototype = TwoDShape baharu; Triangle.prototype.constructor = Segi tiga;
Triangle.prototype.name = 'Segitiga';
Triangle.prototype.getArea = function(){
kembalikan this.side*this.height/2; }


Tulis semula (laluan rujukan bukannya nilai):




Salin kod


Kod adalah seperti berikut:
function Shape(){}

Shape.prototype.name = 'shape';
Shape.prototype.toString = function(){

kembalikan this.name; } fungsi TwoDShape(){} TwoDShape.prototype = Bentuk.prototaip; TwoDShape.prototype.constructor = TwoDShape
TwoDShape.prototype.name = 'bentuk 2d';
fungsi Segitiga(sisi, tinggi){
this.side = sebelah; ini.tinggi = tinggi; }

Triangle.prototype = TwoDShape.prototype; Triangle.prototype.constructor = Segi tiga;
Triangle.prototype.name = 'Segitiga'; Triangle.prototype.getArea = function(){
kembalikan this.side*this.height/2; }


Walaupun ia meningkatkan kecekapan, kaedah ini mempunyai kesan sampingan Kerana ia diluluskan melalui rujukan dan bukannya nilai, nilai nama dalam "objek induk" terjejas.
Objek anak dan objek induk menghala ke objek yang sama. Jadi sebaik sahaja objek kanak-kanak mengubah suai prototaipnya, objek induk juga akan ditukar serta-merta.

Tulis semula sekali lagi (menggunakan pembina sementara):




Salin kod


Kod adalah seperti berikut:
fungsi Shape(){}
Shape.prototype.name = 'shape';
Shape.prototype.toString = function(){
kembalikan this.name;
}
fungsi TwoDShape(){}
var F = function(){}
F.prototaip = Bentuk.prototaip; TwoDShape.prototype = baharu F(); TwoDShape.prototype.constructor = TwoDShape
TwoDShape.prototype.name = 'bentuk 2d'; fungsi Segitiga(sisi, tinggi){
this.side = sebelah; ini.tinggi = tinggi; }
F.prototaip = TwoDShape.prototype; Triangle.prototype = F();
Triangle.prototype.constructor = Segi tiga; Triangle.prototype.name = 'Segitiga'; Triangle.prototype.getArea = function(){
kembalikan this.side*this.height/2; }


Walaupun ia meningkatkan kecekapan, kaedah ini mempunyai kesan sampingan Kerana ia diluluskan melalui rujukan dan bukannya nilai, nilai nama dalam "objek induk" terjejas.

Objek kanak-kanak dan objek induk menghala ke objek yang sama. Jadi sebaik sahaja objek kanak-kanak diubah suai dengan menjajarkan prototaip, objek induk juga akan ditukar serta-merta.

Saya harap artikel ini akan membantu reka bentuk pengaturcaraan JavaScript semua orang.
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)
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Tetapan grafik terbaik
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Cara Memperbaiki Audio Jika anda tidak dapat mendengar sesiapa
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Cara Membuka Segala -galanya Di Myrise
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)

Penjelasan terperinci tentang warisan fungsi C++: Bagaimana untuk menggunakan 'penunjuk kelas asas' dan 'penunjuk kelas terbitan' dalam warisan? Penjelasan terperinci tentang warisan fungsi C++: Bagaimana untuk menggunakan 'penunjuk kelas asas' dan 'penunjuk kelas terbitan' dalam warisan? May 01, 2024 pm 10:27 PM

Dalam pewarisan fungsi, gunakan "penunjuk kelas asas" dan "penunjuk kelas terbitan" untuk memahami mekanisme pewarisan: apabila penuding kelas asas menghala ke objek kelas terbitan, transformasi ke atas dilakukan dan hanya ahli kelas asas diakses. Apabila penuding kelas terbitan menghala ke objek kelas asas, hantaran ke bawah dilakukan (tidak selamat) dan mesti digunakan dengan berhati-hati.

Penggunaan fungsi WPSdatedif Penggunaan fungsi WPSdatedif Feb 20, 2024 pm 10:27 PM

WPS ialah suite perisian pejabat yang biasa digunakan, dan fungsi jadual WPS digunakan secara meluas untuk pemprosesan dan pengiraan data. Dalam jadual WPS, terdapat fungsi yang sangat berguna, fungsi DATEDIF, yang digunakan untuk mengira perbezaan masa antara dua tarikh. Fungsi DATEDIF ialah singkatan daripada perkataan Inggeris DateDifference Sintaksnya adalah seperti berikut: DATEDIF(start_date,end_date,unit) dengan start_date mewakili tarikh mula.

Penerangan terperinci dan pengenalan penggunaan fungsi MySQL ISNULL Penerangan terperinci dan pengenalan penggunaan fungsi MySQL ISNULL Mar 01, 2024 pm 05:24 PM

Fungsi ISNULL() dalam MySQL ialah fungsi yang digunakan untuk menentukan sama ada ungkapan atau lajur yang ditentukan adalah NULL. Ia mengembalikan nilai Boolean, 1 jika ungkapan itu NULL, 0 sebaliknya. Fungsi ISNULL() boleh digunakan dalam pernyataan SELECT atau untuk pertimbangan bersyarat dalam klausa WHERE. 1. Sintaks asas fungsi ISNULL(): ISNULL(ungkapan) di mana ungkapan ialah ungkapan untuk menentukan sama ada ia NULL atau

Penjelasan terperinci tentang warisan fungsi C++: Bagaimana untuk menyahpepijat ralat dalam warisan? Penjelasan terperinci tentang warisan fungsi C++: Bagaimana untuk menyahpepijat ralat dalam warisan? May 02, 2024 am 09:54 AM

Petua penyahpepijatan ralat warisan: Pastikan perhubungan warisan yang betul. Gunakan penyahpepijat untuk melangkah melalui kod dan memeriksa nilai pembolehubah. Pastikan anda menggunakan pengubah suai maya dengan betul. Periksa masalah berlian warisan yang disebabkan oleh warisan tersembunyi. Semak fungsi maya tulen yang tidak dilaksanakan dalam kelas abstrak.

Bagaimanakah warisan dan polimorfisme mempengaruhi gandingan kelas dalam C++? Bagaimanakah warisan dan polimorfisme mempengaruhi gandingan kelas dalam C++? Jun 05, 2024 pm 02:33 PM

Pewarisan dan polimorfisme mempengaruhi gandingan kelas: Pewarisan meningkatkan gandingan kerana kelas terbitan bergantung pada kelas asas. Polimorfisme mengurangkan gandingan kerana objek boleh bertindak balas kepada mesej secara konsisten melalui fungsi maya dan penunjuk kelas asas. Amalan terbaik termasuk menggunakan warisan dengan berhati-hati, menentukan antara muka awam, mengelakkan penambahan ahli data pada kelas asas dan menyahgandingkan kelas melalui suntikan kebergantungan. Contoh praktikal yang menunjukkan cara menggunakan polimorfisme dan suntikan pergantungan untuk mengurangkan gandingan dalam aplikasi akaun bank.

Gunakan CSS Transform untuk mengubah elemen Gunakan CSS Transform untuk mengubah elemen Feb 24, 2024 am 10:09 AM

Penggunaan Transform dalam CSS Sifat Transform CSS ialah alat yang sangat berkuasa yang boleh melakukan operasi seperti terjemahan, putaran, penskalaan dan menyengetkan elemen HTML. Ia boleh mengubah penampilan elemen secara mendadak dan menjadikan halaman web lebih kreatif dan dinamik. Dalam artikel ini, kami akan memperkenalkan pelbagai kegunaan Transform secara terperinci dan memberikan contoh kod khusus. 1. Terjemah (Terjemah) Terjemah merujuk kepada menggerakkan elemen pada jarak tertentu di sepanjang paksi-x dan paksi-y. Sintaksnya adalah seperti berikut: tran

Penjelasan terperinci tentang warisan fungsi C++: Bagaimana untuk memahami hubungan 'is-a' dan 'has-a' dalam warisan? Penjelasan terperinci tentang warisan fungsi C++: Bagaimana untuk memahami hubungan 'is-a' dan 'has-a' dalam warisan? May 02, 2024 am 08:18 AM

Penjelasan terperinci tentang pewarisan fungsi C++: Kuasai hubungan antara "is-a" dan "has-a" Apakah pewarisan fungsi? Warisan fungsi ialah teknik dalam C++ yang mengaitkan kaedah yang ditakrifkan dalam kelas terbitan dengan kaedah yang ditakrifkan dalam kelas asas. Ia membenarkan kelas terbitan untuk mengakses dan mengatasi kaedah kelas asas, dengan itu memanjangkan fungsi kelas asas. Perhubungan "is-a" dan "mempunyai-a" Dalam pewarisan fungsi, perhubungan "is-a" bermakna kelas terbitan ialah subjenis kelas asas, iaitu kelas terbitan "mewarisi" ciri dan tingkah laku kelas asas. Perhubungan "mempunyai-a" bermaksud bahawa kelas terbitan mengandungi rujukan atau penunjuk kepada objek kelas asas, iaitu, kelas terbitan "memiliki" objek kelas asas. SintaksBerikut ialah sintaks untuk cara melaksanakan pewarisan fungsi: classDerivedClass:pu

Penggunaan permintaan POST yang betul dalam PHP Penggunaan permintaan POST yang betul dalam PHP Mar 27, 2024 pm 03:15 PM

Penggunaan permintaan POST dalam PHP adalah operasi biasa dalam pembangunan laman web Data boleh dihantar ke pelayan melalui permintaan POST, seperti data borang, maklumat pengguna, dll. Penggunaan permintaan POST yang betul boleh memastikan keselamatan dan ketepatan data Perkara berikut akan memperkenalkan penggunaan permintaan POST yang betul dalam PHP dan memberikan contoh kod tertentu. 1. Prinsip asas permintaan POST dalam PHP Dalam PHP, data yang dihantar melalui kaedah POST boleh diperoleh dengan menggunakan pembolehubah global $_POST. Kaedah POST menukar nombor borang menjadi

See all articles