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

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

方式1:布尔判定

js 复制代码
var obj = {}

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

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

  • 注意:
    当"属性a"的值是undefined、null、 " "、0时,同样视为不存在
  • 原因:

方式2:使用undefined

属性a的值与"undefined"对比

方式3:使用Object.keys()

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

  • 自有属性
js 复制代码
var obj = { a: 1 }   或者   obj.a = 1
  • 非自有属性
js 复制代码
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"

可以是非自有属性、不可枚举、原型上都行

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

总结:

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

相关推荐
前端付豪5 分钟前
1、震惊!99% 前端都没搞懂的 JavaScript 类型细节
前端·javascript·面试
朝与暮5 分钟前
js符号(Symbol)
前端·javascript
大怪v1 小时前
前端:人工智能?我也会啊!来个花活,😎😎😎“自动驾驶”整起!
前端·javascript·算法
遂心_3 小时前
为什么 '1'.toString() 可以调用?深入理解 JavaScript 包装对象机制
前端·javascript
王同学QaQ3 小时前
Vue3对接UE,通过MQTT完成通讯
javascript·vue.js
程序员鱼皮4 小时前
刚刚 Java 25 炸裂发布!让 Java 再次伟大
java·javascript·计算机·程序员·编程·开发·代码
Asort4 小时前
JavaScript 从零开始(五):运算符和表达式——从零开始掌握算术、比较与逻辑运算
前端·javascript
一枚前端小能手4 小时前
🚀 缓存用错了网站更慢?前端缓存策略的5个致命误区
前端·javascript
艾小码4 小时前
为什么你的页面会闪烁?useLayoutEffect和useEffect的区别藏在这里!
前端·javascript·react.js
艾小码4 小时前
告别Vue混入的坑!Composition API让我效率翻倍的3个秘密
前端·javascript·vue.js