JavaScript 的 原型和原型链

本文深入探讨JavaScript中的引用类型,如数组、对象和函数,及其如何通过__proto__属性和构造函数的prototype属性形成原型链。通过示例代码,详细解释了当调用对象属性和方法时,JavaScript引擎如何在原型链上进行查找。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在JavaScript中,数组,对象和函数被称为引用类型,他们都有一个__proto__属性,该属性是一个对象(我们称之为隐式原型)
在这里插入图片描述
数组的构造函数是Array,Array构造函数中有一个prototype属性,(我们暂时称之为显式原型)
在这里插入图片描述
arr是构造函数的实例对象,arr中的__proto__对象指向构造函数中的prototype对象
在这里插入图片描述
demo

    function Animal(name) {
        this.name = name;
    }

    Animal.prototype.eat = function () {
        console.log('Animal is eat');
    };

    let dog = new Animal('dog');
    
    console.dir(dog);

dog对象 的属性:
在这里插入图片描述
调用dog的属性和方法时,会先从dog本身去查找,如果dog本身没有那个属性或方法,就会去dog的__proto__原型中去查找,而__proto__又指向Animal的prototype(看第二个constructor对象,指向Animal),这就是原型链
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值