Rumah > hujung hadapan web > tutorial js > Penjelasan terperinci tentang pembina JavaScript dan prototaip dengan contoh

Penjelasan terperinci tentang pembina JavaScript dan prototaip dengan contoh

WBOY
Lepaskan: 2022-11-24 17:44:44
ke hadapan
1225 orang telah melayarinya

Artikel ini membawakan anda pengetahuan yang berkaitan tentang JavaScript terutamanya isu berkaitan tentang pembina dan prototaip, serta kandungan berkaitan prototaip. Saya harap ia akan membantu kepada semua orang.

Penjelasan terperinci tentang pembina JavaScript dan prototaip dengan contoh

[Cadangan berkaitan: Tutorial video JavaScript, bahagian hadapan web]

1 prototaip

1.1 Gunakan prototaip untuk menyelesaikan masalah sisa ingatan

Kelemahan: Terdapat masalah pembaziran ingatan,

Jika terdapat dua objek atau lebih, ruang jenis data yang kompleks akan diperuntukkan beberapa kali

Prototaip pembinaprototaipObjek prototaip terutamanya menyelesaikan masalah sisa memori Fungsi yang diperuntukkan oleh pembina melalui prototaip dikongsi oleh semua objek Kongsi. Setiap pembina dalam JavaScript mempunyai sifat prototaip yang menunjuk ke objek lain. Prototaip ini ialah objek, dan semua sifat dan kaedah objek prototaip akan dimiliki oleh pembina. Pada masa ini, anda boleh menggunakan prototaip untuk meletakkan kaedah di dalamnya untuk digunakan oleh semua objek contoh objek.

Prototaip objek_ proto_ Objek

Setiap objek akan mempunyai atribut _ proto_ menunjuk ke objek prototaip pembina Sebab mengapa objek kita boleh menggunakan sifat dan kaedah objek prototaip pembina adalah kerana objek mempunyai _ proto_ Kewujudan prototaip.

_ proto_ sy dan _ proto_ sym adalah kaedah carian kaedah yang sama: mula-mula lihat sy dan sama ada terdapat kaedah sing pada objek sym, laksanakan ini Nyanyi pada objek, kerana terdapat _ _ proto _ _, pergi ke prototaip objek fungsi pembina Prototaip, dan pergi ke objek prototaip fungsi pembina Prototaip untuk mencari kaedah nyanyian ( Ringkasnya, saya menggunakannya jika Saya mempunyainya, jika tidak, pergi ke objek prototaip dan cari ) Apabila fungsi dan objek dicipta, sifat akan dibuat secara automatik. Kedua-duanya menunjuk ke objek kosong yang sama

1.2 pembina pembina pembina Pembina

objek prototaip (_ proto _) dan pembina ( prototaip ) objek prototaip mempunyai sifat pembina harta, pembina Kami memanggilnya sebagai pembina kerana ia merujuk kembali kepada pembina itu sendiri .

Kedua-duanya mempunyai konstruktor Jika prototaip ditambah dalam bentuk objek, maka penunjuk prototaip telah berubah dan menunjuk kepada yang baharu. Objek prototaip objek baharu ini tidak menghala ke konstruktor Anda perlu menghalakannya secara manual ke

2. Rantaian prototaip

2.1 Peraturan carian ahli dalam js

Apabila mengakses sifat (termasuk kaedah) objek, semak dahulu sama ada objek itu sendiri mempunyai sifat itu. Jika tidak, cari prototaipnya (iaitu, objek prototaip prototaip yang ditunjuk oleh ._ proto _). Jika ia belum wujud lagi, cari prototaip objek prototaip (objek prototaip Objek). Dan seterusnya sehingga Objek ditemui (null).

2.2 Objek prototaip ini menunjuk kepada

1 Dalam pembina, ini menunjukkan contoh objek shanyu

<script>
        function Person(uname, uage) {
            this.uname = uname;
            this.uage = uage;
        }
        // 声明一个变量然后验证this指向是不是和实例化对象相同
        var that;
        Person.prototype.skill = function () {
            console.log('我会吃饭');
            that = this;
        }
        var shanyu = new Person('山鱼', 30);
        shanyu.skill();
        console.log(that === shanyu);
    </script>
Salin selepas log masuk

2.3 Memanjangkan objek terbina dalam

Anda boleh memanjangkan objek terbina dalam asal dengan kaedah tersuai melalui objek prototaip

 <script>
        //  自定义对象应用,给Array添加一个自定义方法
        Array.prototype.sum = function () {
            var sum = 0;
            for (var i = 0; i < this.length; i++) {
                sum += this[i];
            }
            return sum;
        }
        var arr = [1, 2, 3, 4];
        console.log(arr.sum());
    </script>
Salin selepas log masuk

Array dan rentetan terbina-. dalam Objek tidak boleh menulis ganti objek prototaip dengan operasi Array.prototype = {}.

3.fungsi panggilan

Panggil fungsi ini dan ubah suai penunjuk ini apabila fungsi sedang dijalankan: thisArg Objek yang ditunjuk oleh fungsi panggilan semasa ini arg1, arg2 Parameter lain diluluskan

    <script>
        function sing(x,y) {
            console.log("a~a~给我已被忘情水");
            console.log(this);
            console.log(x+y);
        }
        var fn = {
            name: '山鱼'
        }
        // call()可以改变这个函数的this指向此时这个函数的this就指向了o这个对象
        sing.call(fn,1,2)
    </script>
Salin selepas log masuk

4. Warisi

Daripada apa yang kita taip, kita dapat melihat bahawa ini menunjukkan kepada Son, iaitu, Son menggunakan uname dalam pembina induk, uage

4.1 Gunakan warisan objek prototaip

Tiada lanjutan sebelum es6, jadi anda boleh menggunakan gabungan objek pembina dan model untuk melaksanakan operasi pewarisan

 <script>
        function Father(uname, uage) {
            this.uname = uname;
            this.uage = uage;
        }
        Father.prototype.eat = function () {
            console.log("我爱吃鸡腿");
        }
        // 子构造函数
        Son.prototype = new Father();
        Son.prototype.constructor = Son;
        function Son(uname, uage, swing) {
            Father.call(this, uname, uage);
            this.swing = swing;
        }
        Son.prototype.student = function () {
            console.log('我爱学习!!');
        }
        // 要向使用父亲原型对象里面的方法,可以实例化一下Father,然后
        // 这时候Son的this指向到了Father,所以我们要用constructor将this指回到Son
        var son = new Son('山鱼妹', 18, "游泳冠军!!!");
        // console.log(son.eat());
        console.log(son);
        console.log(Father.prototype);
    </script>
Salin selepas log masuk

[Cadangan berkaitan: Tutorial video JavaScript, bahagian hadapan web]

Atas ialah kandungan terperinci Penjelasan terperinci tentang pembina JavaScript dan prototaip dengan contoh. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Label berkaitan:
sumber:csdn.net
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
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan