JavaScript如何判断对象中的属性存在自身还是原型链上 您所在的位置:网站首页 js获取原型的方法有 JavaScript如何判断对象中的属性存在自身还是原型链上

JavaScript如何判断对象中的属性存在自身还是原型链上

2024-07-16 17:09| 来源: 网络整理| 查看: 265

1.in操作符

in 操作符会在通过对象能够访问给定属性时返回true,无论该属性存在于对象本身还是其原型链上。

function Person(name) { this.name = name } let obj = new Person('Tom') Person.prototype.gender = 'male' Person.prototype.code = 23 console.log("name" in obj) // true console.log('code' in obj) // true console.log('gender' in obj) // true

 2.obj.hasOwnProperty(prop)

hasOwnProperty() 方法会返回一个布尔值,指示对象自身属性中是否具有指定的属性。

对象本身有,返回true;反之,返回false。

function Person(name) { this.name = name } let obj = new Person('Tom') Person.prototype.gender = 'male' Person.prototype.code = 23 console.log(obj.hasOwnProperty('name')) // true console.log(obj.hasOwnProperty('code')) // false console.log(obj.hasOwnProperty('gender')) // false

 3.两者结合判断属性位于对象本身还是来自于其原型链

function Person(name) { this.name = name } let obj = new Person('Tom') Person.prototype.gender = 'male' Person.prototype.code = 23 function propertyFormPrototype(obj, prop) { return obj.hasOwnProperty(prop) && prop in obj //当return为true时表示属性位于对象本身 } console.log(propertyFormPrototype(obj, 'name')) // true console.log(propertyFormPrototype(obj, 'gender')) // false console.log(propertyFormPrototype(obj, 'code')) // false



【本文地址】

公司简介

联系我们

今日新闻

    推荐新闻

    专题文章
      CopyRight 2018-2019 实验室设备网 版权所有