区分对象自身的属性和从原型对象上继承的属性

本文介绍了如何在JavaScript中通过hasOwnProperty、in操作符和Object.getPrototypeOf方法区分对象自身的属性与从原型继承的属性,并提供了hasOwnProp函数作为实例,帮助开发者准确判断属性来源。
摘要由CSDN通过智能技术生成

在JavaScript中,你可以使用几种方法来区分一个对象自身的属性(即直接定义在该对象上的属性)和从原型对象上继承的属性。以下是一些常用的方法:

  1. 使用hasOwnProperty方法
    Object.prototype.hasOwnProperty 方法返回一个布尔值,指示对象自身属性中是否具有指定的属性,而不是其原型链上的属性。
const obj = {
  prop1: 'value1',
  prop2: 'value2'
};

console.log(obj.hasOwnProperty('prop1')); // true
console.log(obj.hasOwnProperty('prop2')); // true
console.log(obj.hasOwnProperty('toString')); // false,因为toString是从原型上继承的
  1. 使用in操作符
    in 操作符用于检查对象是否包含某个属性,无论该属性是对象自身的属性还是从其原型链上继承的属性。
const obj = {
  prop1: 'value1',
  prop2: 'value2'
};

console.log('prop1' in obj); // true
console.log('prop2' in obj); // true
console.log('toString' in obj); // true,因为toString是从原型上继承的
  1. 使用Object.getPrototypeOf方法
    你可以使用Object.getPrototypeOf方法来获取一个对象的原型,然后检查原型上是否包含某个属性。
const obj = {
  prop1: 'value1',
  prop2: 'value2'
};

const proto = Object.getPrototypeOf(obj);

console.log(proto.hasOwnProperty('toString')); // true,因为toString是定义在原型上的

结合使用hasOwnPropertyin操作符,你可以准确地确定一个属性是否是对象自身的属性,还是从原型链上继承的属性。例如:

const obj = {
  prop1: 'value1',
  prop2: 'value2'
};

function hasOwnProp(obj, propName) {
  return obj.hasOwnProperty(propName) 
  		 ||(propName in obj && obj.constructor.prototype.hasOwnProperty(propName));
}

console.log(hasOwnProp(obj, 'prop1')); // true
console.log(hasOwnProp(obj, 'prop2')); // true
console.log(hasOwnProp(obj, 'toString')); // false

在这个例子中,hasOwnProp函数首先检查属性是否是对象自身的属性。如果不是,它会进一步检查该属性是否从原型链上继承而来。如果是从原型链上继承而来,并且该属性是定义在构造函数的原型上的,那么hasOwnProp函数会返回false

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

java硕哥

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值