JavaScript原型对象,原型链

参考:https://blog.csdn.net/aiden_Jerray/article/details/82976885?biz_id=102&utm_term=javascriopt%E5%8E%9F%E5%9E%8B%E5%8E%9F%E5%9E%8B%E9%93%BE%E5%AF%B9%E8%B1%A1%E9%97%AE%E9%A2%98&utm_medium=distribute.pc_search_result.none-task-blog-2allsobaiduweb~default-0-82976885&spm=1018.2118.3001.4187

我们知道原型式一个对象,其他对象可以通过他的属性实现继承,但是_proto_又是什么呢?

一、prototype和__proto__的区别

在这里插入图片描述
主要是prototype是函数才有的属性
而__proto__是每个对象都有的属性

<script>
        var a = {};
        console.log(a.prototype);  //undefined
        console.log(a.__proto__);  //Object {}
</script>

在这里插入图片描述

在这里插入图片描述
在这里插入图片描述

 <script>
        /*1、字面量方式*/
        var a = {};
        console.log(a.__proto__);  //Object {}

        console.log(a.__proto__ === a.constructor.prototype); //true

        /*2、构造器方式*/
        var A = function () { };
        var a = new A();
        console.log(a.__proto__); //A {}

        console.log(a.__proto__ === a.constructor.prototype); //true

        /*3、Object.create()方式*/
        var a1 = { a: 1 }
        var a2 = Object.create(a1);
        console.log(a2.__proto__); //Object {a: 1}

        console.log(a.__proto__ === a.constructor.prototype); //false(此处即为图1中的例外情况)
    </script>

在这里插入图片描述
在这里插入图片描述

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值