首页 >

es6怎么判断对象有没有某属性

web前端|前端问答es6怎么判断对象有没有某属性
es6,对象
web前端-前端问答
彩票统计分析软件源码,ubuntu如何更改主机,pfx证书安装到tomcat,递归爬虫 深度,php 打开epub,机械行业seo优化哪家专业lzw
es6判断对象有没有某属性
任务 积分商城 源码,ubuntu终端资源监视,tomcat怎么启动微服务,爬虫跟踪ajax,sql可以执行php吗,这台seolzw
方法1:点( . )+ undefined判断
php获取网页源码,ubuntu找不so,怎么用tomcat编网页,java 爬虫异步,php项目单机部署,十堰工程机械seo推广多少钱lzw
我们知道,通过点或者方括号可以获取对象的属性值,如果对象上不存在该属性,则会返回 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 = undefinedconsole.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')  // trueobj.hasOwnProperty('nationality')  // false 原型链上继承的属性

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


  • 暂无相关文章
  • Posted in 未分类