JavaScript原型,原型链 超详解

  1. 对象
    JS中一切皆是对象,每个对象都有一个__proto__属性,该属性也是一个对象(包含constructor属性和__proto__属性),那么自身也必然存在一个__proto__,这样逐级向上,就形成了一个链式,这个链式就被称为原型链
    当然它并不是永不停止地向上查找,__proto__的继承的终极是Object。Object是所有对象的顶级对象。

  2. 函数
    函数除了具有__proto__之外,还有一个独特的prototype 属性,这个属性也是一个对象,包含constructor属性和__proto__属性。

  3. constructor,__proto__和prototype

var Foo=function(){};
var f1=new Foo();
  • __proto__指向它的构造函数的原型对象
console.log(f1.__proto__===Foo.prototype);//true
  • constructor指向它的构造函数
console.log(f1.constructor===Foo);//true
  • Foo.prototype即原型对象,包含__proto__和constructor
console.log(Foo.prototype.constructor===Foo);//true
//这一点毫无疑问,Foo.prototype的构造函数是Foo
console.log(Foo.prototype.__proto__===Object.prototype);//true
//这是因为Foo.prototype是普通对象,所以它的__proto__指向Object.prototype,
这一点在下文有更进一步的解释

因此,就可以得出这一整个原型链为
在这里插入图片描述
通过借助一位大神的图来整理一下以上说明:
在这里插入图片描述
针对这张图,补充说明几点:

  • JS中一切皆对象,但是对象分普通对象和函数对象。通过new Function()创建的都是函数对象,而下面的f1和f2本质上也是通过new Function()创建的。
var o1 = {}; 
var o2 = new Object();
var o3 = new f1();

function f1(){}; 
var f2 = function(){};
var f3 = new Function('str','console.log(str)');

console.log(typeof f1); //function 
console.log(typeof f2); //function 
console.log(typeof f3); //function   

console.log(typeof o1); //object 
console.log(typeof o2); //object 
console.log(typeof o3); //object
  • 构造器都是函数对象
    在这里插入图片描述
    所以,他们的__proto__也指向Function.prototype
console.log(Object.__proto__===Function.prototype);//true
console.log(Array.__proto__===Function.prototype);//true
//其他的几个也都是
  • 原型对象是普通对象而不是函数对象,因为它不是通过new Function()创建的(Function.prototype除外,但是,虽然它是函数对象,却没有prototype属性,所以他的__proto__指向Object.prototype)(这也就解释了为什么Foo.prototype.__proto__指向Object的原型对象)
console.log(typeof Object.prototype);//object
console.log(typeof Function.prototype);//function
console.log(Function.prototype.prototype);//undefined
console.log(Function.prototype.__proto__===Object.prototype);//true
//其他的几个也都是
  • 原型链的终点是null,它是一个普通对象,但是它是空的,没有__ptoto__和constructor属性
console.log(Object.prototype.__proto__===null);//true
console.log(typeof null);//object
console.log(null.__ptoto__);//Uncaught TypeError: Cannot read property '__ptoto__' of null
console.log(null.constructor);//Uncaught TypeError: Cannot read property 'constructor' of null

参考文献

  • [1] https://www.jianshu.com/p/dee9f8b14771
  • [2] https://www.jianshu.com/p/652991a67186
  • 1
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值