深入javascript之原型和原型链

作者 : 开心源码 本文共2570个字,预计阅读时间需要7分钟 发布时间: 2022-05-11 共69人阅读

原型和原型链是js中的难点也是重点,明白了原型和原型链会让我们在后面不论是学习还是工作都会更加高效,并且原型和原型链会是面试中必不可少的话题。看完此篇文章肯定会让你对原型,原型链有深刻全面的理解。

一. 函数对象

所有引使用类型(函数,数组,对象)都拥有proto属性(隐式原型)
所有函数拥有prototype属性(显式原型)(仅限函数)
原型对象:拥有prototype属性的对象,在定义函数时就被创立

二. 构造函数

先复习下构造函数

//创立构造函数        function Word(words){            this.words = words;        }        Word.prototype = {            alert(){                alert(this.words);            }        }        //创立实例        var w = new Word("hello world");        w.print = function(){            console.log(this.words);            console.log(this);  //Person对象        }        w.print();  //hello world        w.alert();  //hello world

print()方法是w实例本身具备的方法,所以w.print()打印hello world;alert()不属于w实例的方法,属于构造函数的方法,w.alert()也会打印hello world,由于实例继承构造函数的方法。

实例w的隐式原型指向它构造函数的显式原型,指向的意思是恒等于

                             w.__proto__ === Word.prototype

当调使用某种方法或者查找某种属性时,首先会在自身调使用和查找,假如自身并没有该属性或者方法,则会去它的 __ proto __ 属性中调使用查找,也就是它构造函数的prototype中调使用查找。所以很好了解实例继承构造函数的方法和属性:

w本身没有alert()方法,所以会去Word()的显式原型中调使用alert(),即实例继承构造函数的方法。

三,原型和原型链

        Function.prototype.a = "a";        Object.prototype.b = "b";        function Person(){}        console.log(Person);    //function Person()        let p = new Person();        console.log(p);         //Person {} 对象        console.log(p.a);       //undefined        console.log(p.b);       //b

想一想p.a打印结果为undefined,p.b结果为b
解析: p是Person()的实例,是一个Person对象,它拥有一个属性值__ proto __,并且 __ proto __是一个对象,包含两个属性值constructor和 __ proto __

        console.log(p.__ proto__ .constructor);   //function Person(){}        console.log(p.__ proto __.__proto__);     //对象{},拥有很多属性值

我们会发现p. __ proto __ .constructor返回的结果为构造函数本身,p. __ proto __ . __ proto __ 有很多参数。

image.png

我们调使用constructor属性,p. __ proto __ . __ proto __ .constructor得到拥有多个参数的Object()函数,Person.prototype的隐式原型的constructor指向Object(),即Person.prototype. __ proto __ .constructor == Object()

从p. __ proto __ .constructor返回的结果为构造函数本身得到Person.prototype.constructor == Person()所以p. __ proto __ . __ proto __ == Object.prototype

所以p.b打印结果为b,p没有b属性,会一直通过__ proto __向上查找,最后当查找到Object.prototype时找到,最后打印出b,向上查找过程中,得到的是Object.prototype,而不是Function.prototype,找不到a属性,所以结果为undefined,这就是原型链,通过 __ proto __ 向上进行查找,最终到null结束

        console.log(p.__proto__.__proto__.__proto__);   //null        console.log(Object.prototype.__proto__);        //null

大家了解刚才的过程,相信下面这些应该也都明白

        //Function        function Function(){}        console.log(Function);  //Function()        console.log(Function.prototype.constructor);    //Function()        console.log(Function.prototype.__proto__);      //Object.prototype        console.log(Function.prototype.__proto__.__proto__);    //NULL        console.log(Function.prototype.__proto__.constructor);  //Object()        console.log(Function.prototype.__proto__ === Object.prototype); //true

总结:

  1. 查找属性,假如本身没有,则会去__ proto __ 中查找,也就是构造函数的显式原型中查找,假如构造函数中也没有该属性,由于构造函数也是对象,也有__ proto __,那么会去它的显式原型中查找,一直到null,假如没有则返回undefined

  2. p.__ proto __.constructor == function Person(){}

3 .p.__ proto . proto __== Object.prototype

4 .p.__ proto . proto . proto __== Object.prototype. __ proto __ == null

5 .通过__ proto __形成原型链而非protrotype

最后附上一张图,大家阅读完之后,看图应该能很容易了解

image.png

说明
1. 本站所有资源来源于用户上传和网络,如有侵权请邮件联系站长!
2. 分享目的仅供大家学习和交流,您必须在下载后24小时内删除!
3. 不得使用于非法商业用途,不得违反国家法律。否则后果自负!
4. 本站提供的源码、模板、插件等等其他资源,都不包含技术服务请大家谅解!
5. 如有链接无法下载、失效或广告,请联系管理员处理!
6. 本站资源售价只是摆设,本站源码仅提供给会员学习使用!
7. 如遇到加密压缩包,请使用360解压,如遇到无法解压的请联系管理员
开心源码网 » 深入javascript之原型和原型链

发表回复