如何获取一个对象的原型对象

函数的prototype属性
1、每个函数都有一个protopype属性,它默认指向一个Object空对象(即称为:原型对象)
原型对象中有一个constructor,它指向函数对象

 

console.log(Cat.prototype.constructor === Cat)

2、给原型对象添加属性(一般是方法)===>实例对象可以访问

========
显式原型与隐式原型
1.每个函数function都有一个prototype,即显式原型(属性)
2.每个实例对象都有一个__proto__,可称为隐式原型
3.对象的隐式原型的值为其对应构造函数的显式原型的值
总结:
函数的prototype属性:在定义函数时自动添加的,默认值是一个空Object对象
对象的__proto__属性:创建对象时自动添加的,默认值为构造函数的prototype属性值
程序员能直接操作显式原型,但不能直接操作隐式原型(ES6之前)

1.读取对象的属性值时:会自动到原型链中查找
2.设置对象的属性值时:不会查找原型链,如果当前对象中没有此属性,直接添加此属性并设置其值
3.方法一般定义在原型中,属性一般通过构造函数定义在对象本身上

那么,在javaScript中如何获取一个对象的原型对象呢?

举个栗子:

  function Cat(name, age) {
            this.name = name
            this.age = age
            this.fun = function () {
                console.log(this.name, this.age)
            }
        }
        let cat1 = new Cat('小橘', 3)
        let a = Object.getPrototypeOf(cat1)
        let b = Cat.prototype
        let c = cat1.__proto__

        
        console.log(a)
        console.log(b)
        console.log(c)
        console.log(a === b)
        console.log(a === c)
        console.log(b === c)// 实例对象的隐式原型等于构造函数的显示原型

  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值