概述
本教程操作环境:windows7系统、ECMAScript 6版、Dell G3电脑。
es6判断对象有没有某属性
方法1:点( . )+ undefined判断
我们知道,通过点或者方括号可以获取对象的属性值,如果对象上不存在该属性,则会返回 undefined。这种方式可以判断指定对象的自有属性和继承属性,如果对象自身没有检测的属性,而原型链上有该属性,则会返回原型链上的属性值。
// 创建对象
let obj = {
name: 'Scarlett',
age: 37
}
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
})
登录后复制
简单的,我们可以通过 Object.propertyName !== undefined 的返回值来判断对象上是否含有某属性。但有一种情况,即:属性名存在,属性值为 undefined 的情况下,就不能返回想要的结果。
// 新增一个值为undefined的属性
obj.birthday = undefined
console.log(obj.birthday !== undefined) // false
登录后复制
那么,我们可以使用 in 运算符来解决这个问题。
方法2:in 运算符
该方法可以判断指定对象的自有属性和继承属性中是否存在某属性,如果存在则返回 true。 in 运算符也能检测到原型链上的属性。
'name' in obj // true 自身属性存在
'occupation' in obj // true 不可枚举属性存在
'nationality' in obj // true 继承属性
'birthday' in obj // true 值为undefined的属性
登录后复制
in 运算符的语法也很简单,作用范围和效果与点( . )或方括号( [ ] )相同,不同的是值为 undefined 的属性也可以正常判断。
以上这两种方法的局限性就是:不能准确区分是自有属性还是原型链上的属性。如果检测自身属性是否存在时,就需要 Object.hasOwnProperty() 了。
方法3:Object.hasOwnProperty()
Object.hasOwnProperty() 用来判断指定对象自身是否含有某个属性(非继承),返回布尔值。
obj.hasOwnProperty('name') // true 自身属性
obj.hasOwnProperty('occupation') // true 不可枚举属性
obj.hasOwnProperty('birthday') // true
obj.hasOwnProperty('nationality') // false 原型链上继承的属性
登录后复制
该方法会过滤掉那些继承来的属性,当检测属性为自有属性时返回 true。
【相关推荐:javascript视频教程、web前端】
以上就是es6怎么判断对象有没有某属性的详细内容,更多请关注靠谱客其它相关文章!
最后
以上就是淡定机器猫为你收集整理的es6怎么判断对象有没有某属性的全部内容,希望文章能够帮你解决es6怎么判断对象有没有某属性所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
发表评论 取消回复