共计 2258 个字符,预计需要花费 6 分钟才能阅读完成。
判断对象中是否含有某个属性也是理论我的项目中常见的场景,现总结如下几种办法来判断。
本文关联文章之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()
办法取得可枚举属性名组成的数组,而后再检测该属性名是否存在于这个数组中。