温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

es6如何判断对象有没有某属性

发布时间:2022-04-11 15:35:55 来源:亿速云 阅读:535 作者:iii 栏目:web开发

这篇“es6如何判断对象有没有某属性”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“es6如何判断对象有没有某属性”文章吧。

判断方法:1、用“对象.属性名 !== undefined”语句判断,如果返回值为true,则对象上有某属性;2、用“'属性名' in 对象”语句,如果返回true则有某属性;3、用“对象.hasOwnProperty('属性名')”语句。

本教程操作环境: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。

以上就是关于“es6如何判断对象有没有某属性”这篇文章的内容,相信大家都有了一定的了解,希望小编分享的内容对大家有帮助,若想了解更多相关的知识内容,请关注亿速云行业资讯频道。

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

es6
AI