JS判断对象属性是否存在的方法是什么
这篇文章主要介绍了JS判断对象属性是否存在的方法是什么的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇JS判断对象属性是否存在的方法是什么文章都会有所收获,下面我们一起来看看吧。
背景
在这篇Accessible Object.prototype.hasOwnProperty() 提案中,提出了一个更简单的方法来检查对象时候具有特定的属性-
Object.hasOwn(),主要目标是用来替代Object.prototype.hasOwnProperty()。目前本提案已经进去第四阶段,预计2022年纳入标准。
随着Object.hasOwn()的加入,目前我们已经有了5个判断对象属性是否存在的方法!
检查属性是否存在
in
JavaScript的in操作符可以用来判断一个属性是否属于一个对象,也可以用来变量一个对象的属性
本文我们只讨论in的检查作用
in运算符检查对象是否具有给定名称的属性:
> 'name' in {name: '搞前端的半夏'}true> 'name' in {}false
但是因为in会判断继承过来的属性!
> 'toString' in {}true
那是因为{}继承了方法Object.prototype.toString()
Reflect.has()
Reflect是在ES2015新增的一个内置对象,提供了与Javascript对象交互的方法。
判断一个对象是否存在某个属性,和 in 运算符] 的功能完全相同。
用法:Reflect.has(obj, propName)
Reflect.has({name:"搞前端的半夏"}, "name"); // trueReflect.has({name:"搞前端的半夏"}, "age"); // falseReflect.has({name:"搞前端的半夏"}, "toString"); //true
hasOwnProperty
hasOwnProperty这个方法可以用来检测一个对象是否含有特定的自身属性,即是用来判断一个属性是定义在对象本身而不是继承自原型链的,
通过对象字面量或者构造函数法创建的对象都从Object.prototype继承了hasOwnProperty()。
构造函数法
o = new Object();o.name = '搞前端的半夏';o.hasOwnProperty('name'); // 返回 trueo.hasOwnProperty('toString'); // 返回 falseo.hasOwnProperty('hasOwnProperty'); // 返回 false
对象字面量
o={name:"搞前端的半夏"}o.hasOwnProperty('name'); // 返回 trueo.hasOwnProperty('toString'); // 返回 falseo.hasOwnProperty('hasOwnProperty'); // 返回 false
缺点
不支持create
但是下面这种情况:
o = Object.create(null)o.hasOwnProperty('name'); // 返回 true
会直接报错:
Uncaught TypeError: o.hasOwnProperty is not a function at <anonymous>:1:3
覆盖报错
如果一个对象有一个自己的名为 name 的属性'hasOwnProperty'
,那么该属性将被覆盖Object.prototype.hasOwnProperty
并且我们无法访问它:
o={hasOwnProperty:"搞前端的半夏"}o.hasOwnProperty('name');
直接报错
VM123:3 Uncaught TypeError: o.hasOwnProperty is not a function at <anonymous>:3:3
Object.prototype.hasOwnProperty()
用法:Object.prototype.hasOwnProperty.call(obj, propName);,接受两个参数。请注意我们这里用到了call。改变this的指向。
Object.prototype.hasOwnProperty除了支持hasOwnProperty的相同用法,同时还解决了hasOwnProperty的两个缺点。
o={hasOwnProperty:"搞前端的半夏"}Object.prototype.hasOwnProperty.call.hasOwnProperty(o,'name'); // 返回false
ES13(ES2022)Object.hasOwn()
Object.hasOwn(),目前来看就是替代Object.prototype.hasOwnProperty.call()。
如果用Object.prototype.hasOwnProperty.call() 来封装的话,代码如下:
function hasOwn(obj, propName) { return Object.prototype.hasOwnProperty.call(obj, propName);}
Object.hasOwn({name: '搞前端的半夏'}, 'name') // trueObject.hasOwn({}, 'name') //falseObject.hasOwn({}, 'toString') //falseObject.hasOwn(Object.create(null), 'name') //falseObject.hasOwn({hasOwnProperty: 'yes'}, 'name') //falseObject.hasOwn({hasOwn: 'yes'}, 'name') //false
关于“JS判断对象属性是否存在的方法是什么”这篇文章的内容就介绍到这里,感谢各位的阅读!相信大家对“JS判断对象属性是否存在的方法是什么”知识都有一定的了解,大家如果还想学习更多知识,欢迎关注编程网行业资讯频道。
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341