H5W3
当前位置:H5W3 > JavaScript > 正文

【JS】JavaScript 判断对象中是否含有某个属性

JavaScript 判断对象中是否含有某个属性

sugar_coffee发布于 今天 01:08

判断对象中是否含有某个属性也是实际项目中常见的场景,现总结如下几种方法来判断。
本文关联文章之JavaScript遍历对象的几种方法

一、点( . )或者方括号( [ ] ) + undefined判断

我们知道,通过点或者方括号可以获取对象的属性值,如果对象上不存在该属性,则会返回 undefined。这种方式可以判断指定对象的自有属性和继承属性,如果对象自身没有检测的属性,而原型链上有该属性,则会返回原型链上的属性值。

// 创建对象
let obj = {
name: 'Scarlett',
age: 37
}
console.log(obj.name !== undefined)  // true 自身属性存在
console.log(obj['name'] !== undefined)  // true
console.log(obj.gender !== undefined)  // false gender属性不存在
// 在原型上添加一个可枚举属性
Object.prototype.nationality = 'America'
// 在obj对象上添加一个不可枚举属性
Object.defineProperty(obj, 'occupation', {
value: 'actress',
enumerable: false
})
console.log(obj.nationality !== undefined) // true
console.log(obj['occupation'] !== undefined)  // true

简单的,我们可以通过 Object.propertyName !== undefined 的返回值来判断对象上是否含有某属性。但有一种情况,即:属性名存在,属性值为 undefined 的情况下,就不能返回想要的结果。

// 新增一个值为undefined的属性
obj.birthday = undefined
​
console.log(obj.birthday !== undefined)  // false

那么,我们可以使用 in 运算符来解决这个问题。

二、in 运算符

该方法可以判断指定对象的自有属性和继承属性中是否存在某属性,如果存在则返回 true。 in 运算符也能检测到原型链上的属性。
附:MDN 上对in运算符的介绍。

'name' in obj  // true 自身属性存在
'occupation' in obj  // true 不可枚举属性存在
'nationality' in obj  // true 继承属性
'birthday' in obj  // true 值为undefined的属性

in 运算符的语法也很简单,作用范围和效果与点( . )或方括号( [ ] )相同,不同的是值为 undefined 的属性也可以正常判断

  • 以上这两种方法的局限性就是:不能准确区分是自有属性还是原型链上的属性。如果检测自身属性是否存在时,就需要 Object.hasOwnProperty() 了。

三、Object.hasOwnProperty()

Object.hasOwnProperty() 用来判断指定对象自身是否含有某个属性(非继承),返回布尔值。

obj.hasOwnProperty('name')  // true 自身属性
obj.hasOwnProperty('occupation')  // true 不可枚举属性
obj.hasOwnProperty('birthday')  // true
obj.hasOwnProperty('nationality')  // false 原型链上继承的属性

该方法会过滤掉那些继承来的属性,当检测属性为自有属性时返回 true。

四、Object.keys()

Object.keys() ES5 新增的一个对象方法,该方法返回指定对象自身的可枚举属性(不含继承的和Symbol属性)组成的数组。

一般的,利用以上三种方法就可以判断指定对象中是否包含某个属性。从上面实例中,我们可以看到当给对象增加一个不可枚举的属性 occupation 时,使用 obj.occupation !== undefined'occupation' in obj obj.hasOwnProperty('occupation') 都返回 true。

但如果我想忽略这个属性,只判断对象中是否含有某个可枚举的属性呢?这就需要用到 Object.keys() 方法了。完整示例如下:

// 创建对象
let obj = {
name: 'Scarlett',
age: 37
}
// 在原型上添加一个可枚举属性
Object.prototype.nationality = 'America'
// 添加一个不可枚举属性
Object.defineProperty(obj, 'occupation', {
value: 'actress',
enumerable: false
})
// 在得到了obj对象自有的可枚举属性之后,剩下的操作就是在数组中查找符合条件的元素了。
Object.keys(obj).includes('occupation')  // false
Object.keys(obj).indexOf('occupation')   // -1

总结

  • 判断一个对象及其原型链是否含有某个属性(枚举、不可枚举及继承属性),使用 in 运算符或点( . )或方括号( [ ] );
  • 判断一个对象自身是否含有某个属性(含枚举、不可枚举属性,不含继承的属性),使用 Object.hasOwnProperty() 方法;
  • 判断一个对象自身是否含有某个可枚举属性,使用 Object.keys() 方法获得可枚举属性名组成的数组,然后再检测该属性名是否存在于这个数组中。
javascript前端es6
阅读 34发布于 今天 01:08
本作品系原创,采用《署名-非商业性使用-禁止演绎 4.0 国际》许可协议
avatar

sugar_coffee
189 声望
1 粉丝

0 条评论
得票时间

avatar

sugar_coffee
189 声望
1 粉丝

宣传栏

判断对象中是否含有某个属性也是实际项目中常见的场景,现总结如下几种方法来判断。
本文关联文章之JavaScript遍历对象的几种方法

一、点( . )或者方括号( [ ] ) + undefined判断

我们知道,通过点或者方括号可以获取对象的属性值,如果对象上不存在该属性,则会返回 undefined。这种方式可以判断指定对象的自有属性和继承属性,如果对象自身没有检测的属性,而原型链上有该属性,则会返回原型链上的属性值。

// 创建对象
let obj = {
name: 'Scarlett',
age: 37
}
console.log(obj.name !== undefined)  // true 自身属性存在
console.log(obj['name'] !== undefined)  // true
console.log(obj.gender !== undefined)  // false gender属性不存在
// 在原型上添加一个可枚举属性
Object.prototype.nationality = 'America'
// 在obj对象上添加一个不可枚举属性
Object.defineProperty(obj, 'occupation', {
value: 'actress',
enumerable: false
})
console.log(obj.nationality !== undefined) // true
console.log(obj['occupation'] !== undefined)  // true

简单的,我们可以通过 Object.propertyName !== undefined 的返回值来判断对象上是否含有某属性。但有一种情况,即:属性名存在,属性值为 undefined 的情况下,就不能返回想要的结果。

// 新增一个值为undefined的属性
obj.birthday = undefined
​
console.log(obj.birthday !== undefined)  // false

那么,我们可以使用 in 运算符来解决这个问题。

二、in 运算符

该方法可以判断指定对象的自有属性和继承属性中是否存在某属性,如果存在则返回 true。 in 运算符也能检测到原型链上的属性。
附:MDN 上对in运算符的介绍。

'name' in obj  // true 自身属性存在
'occupation' in obj  // true 不可枚举属性存在
'nationality' in obj  // true 继承属性
'birthday' in obj  // true 值为undefined的属性

in 运算符的语法也很简单,作用范围和效果与点( . )或方括号( [ ] )相同,不同的是值为 undefined 的属性也可以正常判断

  • 以上这两种方法的局限性就是:不能准确区分是自有属性还是原型链上的属性。如果检测自身属性是否存在时,就需要 Object.hasOwnProperty() 了。

三、Object.hasOwnProperty()

Object.hasOwnProperty() 用来判断指定对象自身是否含有某个属性(非继承),返回布尔值。

obj.hasOwnProperty('name')  // true 自身属性
obj.hasOwnProperty('occupation')  // true 不可枚举属性
obj.hasOwnProperty('birthday')  // true
obj.hasOwnProperty('nationality')  // false 原型链上继承的属性

该方法会过滤掉那些继承来的属性,当检测属性为自有属性时返回 true。

四、Object.keys()

Object.keys() ES5 新增的一个对象方法,该方法返回指定对象自身的可枚举属性(不含继承的和Symbol属性)组成的数组。

一般的,利用以上三种方法就可以判断指定对象中是否包含某个属性。从上面实例中,我们可以看到当给对象增加一个不可枚举的属性 occupation 时,使用 obj.occupation !== undefined'occupation' in obj obj.hasOwnProperty('occupation') 都返回 true。

但如果我想忽略这个属性,只判断对象中是否含有某个可枚举的属性呢?这就需要用到 Object.keys() 方法了。完整示例如下:

// 创建对象
let obj = {
name: 'Scarlett',
age: 37
}
// 在原型上添加一个可枚举属性
Object.prototype.nationality = 'America'
// 添加一个不可枚举属性
Object.defineProperty(obj, 'occupation', {
value: 'actress',
enumerable: false
})
// 在得到了obj对象自有的可枚举属性之后,剩下的操作就是在数组中查找符合条件的元素了。
Object.keys(obj).includes('occupation')  // false
Object.keys(obj).indexOf('occupation')   // -1

总结

  • 判断一个对象及其原型链是否含有某个属性(枚举、不可枚举及继承属性),使用 in 运算符或点( . )或方括号( [ ] );
  • 判断一个对象自身是否含有某个属性(含枚举、不可枚举属性,不含继承的属性),使用 Object.hasOwnProperty() 方法;
  • 判断一个对象自身是否含有某个可枚举属性,使用 Object.keys() 方法获得可枚举属性名组成的数组,然后再检测该属性名是否存在于这个数组中。

本文地址:H5W3 » 【JS】JavaScript 判断对象中是否含有某个属性

评论 0

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址