prototype原型和隐式原型__proto__

prototype原型

在讲解prototype原型前,先说说函数,函数也是一种对象。他也是属性的集合,你也可以对函数进行自定义属性。

函数默认就有一个属性——prototype。对,每个函数都有一个属性叫做prototype

它的含义是函数的原型对象,也就是用这个构造函数创建的实例的原型对象

prototype的属性值是一个对象(属性的集合,再次强调!),默认的只有一个叫做constructor的属性,指向这个函数本身。constructor属性是对象才有的,它是从一个对象指向一个函数,含义就是指向该对象的构造函数。
在这里插入图片描述
如上图,SuperType是是一个函数,右侧的方框就是它的原型。

原型既然作为对象,属性的集合,不可能就只弄个constructor来玩玩,肯定可以自定义的增加许多属性。例如这位Object大哥,人家的prototype里面,就有好几个其他属性。

在这里插入图片描述
你也可以在自己自定义的方法的prototype中新增自己的属性

  function Fn() { }
        Fn.prototype.age= 18;
        Fn.prototype.getName = function () {
            return '老王';
        };

这样就变成了
在这里插入图片描述

 function Fn() { }
 	Fn.prototype.age= 18;
	Fn.prototype.getName = function () {
      return '老王';
 };

var fn = new Fn();
console.log(fn.age);
console.log(fn.getName());

Fn是一个函数,fn对象是从Fn函数new出来的,这样fn对象就可以调用Fn.prototype中的属性。

因为每个对象都有一个隐藏的属性——“proto”,这个属性引用了创建这个对象的函数的prototype。即:fn.proto === Fn.prototype

隐式原型__proto__

每个对象都有一个__proto__,可成为隐式原型
在这里插入图片描述
我们在控制台打印一下可以看到上图的内容,obj.__proto__和Object.prototype的属性一样。

obj这个对象本质上是被Object函数创建的,因此obj._proto_ === Object.prototype。我们可以用一个图来表示。
在这里插入图片描述
即,每个对象都有一个__proto__属性,指向创建该对象的函数的prototype。

自定义函数的prototype本质上就是和 var obj = {} 是一样的,都是被Object创建,所以它的__proto__指向的就是Object.prototype。

上图中的“Object prototype”也是一个对象,但是它是一个特例,它的__proto__指向的是null!
在这里插入图片描述
看完上面又有一个问题,函数的__proto__又是指向哪里的呢?
函数也是被创建出来的。谁创建了函数呢?
Function——注意这个大写的“F”
在这里插入图片描述
我们在控制台中输出上面的内容,可以看到效果是一样的。
第一种方式是比较传统的函数创建方式,第二种是用new Functoin创建(不推荐,这里只是告诉大家它是被谁创建的)。

根据上面说的对象的__proto__指向的是创建它的函数的prototype,就会出现:Object.proto === Function.prototype。用一个图来表示。
在这里插入图片描述
图中,很明显的标出了:自定义函数Foo.__proto__指向Function.prototype,Object.__proto__指向Function.prototype,而Function.__proto__指向Function.prototype形成环形结构。

其实稍微想一下就明白了。Function也是一个函数,函数是一种对象,也有__proto__属性。既然是函数,那么它一定是被Function创建。所以——Function是被自身创建的。所以它的__proto__指向了自身的Prototype。

至于Function.prototype.__proto__的指向,看完上面的内容相信大家都能猜出是指向Object.prototype的了。
在这里插入图片描述

如果你看完这篇文章发现还是不太懂的可以看看我的另外一篇文章typeof 和 instanceof 区别,了解一下instanceof。

关于知识点我是采摘下面博客的内容:

https://www.cnblogs.com/wangfupeng1988/p/3978131.html
https://www.cnblogs.com/wangfupeng1988/p/3979290.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值