JS判断对象中是否存在某个属性

方式1:布尔判定

var obj = {}

if (obj.a) {
  console.log("存在")
} else {
  console.log("不存在") // 输出此结果
}

表示"a"的值是否满足布尔判定

  • 注意:
    当"属性a"的值是undefined、null、 " "、0时,同样视为不存在
    在这里插入图片描述
  • 原因:
    在这里插入图片描述

方式2:使用undefined

属性a的值与"undefined"对比
在这里插入图片描述

方式3:使用Object.keys()

拿到这个对象中所有的属性名形成的数组,看里边是否包含这个属性,并且必须是对象中自有的可枚举属性
在这里插入图片描述

  • 自有属性
var obj = { a: 1 }   或者   obj.a = 1
  • 非自有属性
var obj = {}
function A() {
  A.prototype.a = 1
}
obj = new A()  // 属性a不在它自身上,而是在它的原型链上
console.log(Object.keys(obj)) // 输出: Array []
  • 可枚举属性:
    在这里插入图片描述可以通过Object.keys()或者for in循环找到它就是可枚举属性

修改上面的例子,把属性a变成不可枚举属性:

在这里插入图片描述

方式4:使用 hasOwnProperty()

判断属性是否是对象自有的属性,不要求属性是否可枚举
在这里插入图片描述

方式5:使用"in"

可以是非自有属性、不可枚举、原型上都行
在这里插入图片描述

上述方法没有对错之分,具体情况具体分析

总结:

判断一个对象中是否存在某个属性的方式多种多样,最主要是依据什么去界定这个属性是否存在

  • 9
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值