JavaScript原型链

JavaScript原型链是函数原型对象组成的调用链条,当实例对象找不到属性或方法时,会在原型对象中查找。每个对象都有__proto__指向构造函数的prototype,而原型对象的constructor指向构造函数。原型链会一直向上查找,直到Object的原型对象的__proto__为null,表示原型链结束。所有的对象都是Object的实例,Object.prototype是Function创造的。
摘要由CSDN通过智能技术生成

原型链prototype

什么是原型链,顾名思义,原型链是一条函数原型对象组成的调用链条。JS中每一个函数都有一个原型对象,当实例对象中读取自己的属性或调用方法时找不到该属性和方法时,此时会通过与之关联的prototype原型对象来继续查找,JS利用这个特性模拟“继承”。

function Parent() {
     this.name = '基类';
}

Parent.prototype.study = function () {
     console.log('开始学习啦')
}

var child = new Parent()
child.study();

 这里在构造函数中是没有定义study的,所以实例对象本身也没有study方法,但是这里依然可以调用study方法,因为这里与它关联的原型对象中定义了study方法

指向prototype的__proto__

既然prototype指向了构造函数的原型对象,那跟我们实例对象有什么关系?

function Parent() {
    this.name = '基类';
}

Parent.prototype.study = function () {
    console.log('开始学习啦')
}

var child = new Parent()
child.study();
console.log(child.__proto__ === Parent.prototype); // true

实例对象有个__proto__属性指向了构造函数的prototype,也就是原型对象ÿ

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值