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"

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

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

总结:

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

相关推荐
兆子龙21 分钟前
被忽视的 React 神器:cloneElement 让你的组件开发效率提升 10 倍
前端·javascript
SuperEugene29 分钟前
《this、箭头函数与普通函数:后台项目里最容易写错的几种场景》
前端·javascript
Jing_Rainbow30 分钟前
【React-11/Lesson95(2026-01-04)】React 闭包陷阱详解🎯
前端·javascript·react.js
Zhencode43 分钟前
深入Vue3响应式核心:computed 的实现原理与应用
前端·javascript·vue.js
独自破碎E1 小时前
【滑动窗口】BISHI47 交换到最大
java·开发语言·javascript
是欢欢啊2 小时前
全新的table组件,vue3+element Plus
前端·javascript·vue.js
硬汉嵌入式3 小时前
QEMU & FFmpeg作者Fabrice Bellard推出MicroQuickJS,一款面向嵌入式系统JavaScript引擎,仅需10K RAM
javascript·ffmpeg·microquickjs
小小前端--可笑可笑10 小时前
Vue / React 单页应用刷新 /login 无法访问问题分析
运维·前端·javascript·vue.js·nginx·react.js
小林敲代码778811 小时前
记一次 Vue 项目首屏优化:从 7.1s 到 0.9s,深挖 Gzip 的力量
前端·javascript·vue.js
Highcharts.js11 小时前
什么是向量图表?如何用 Highcharts 快速创建一个笛卡尔坐标图/矢量图?
javascript·开发文档·highcharts·图表开发·向量图·矢量图表·笛卡尔坐标图