当前位置:Gxlcms > JavaScript > JS对象属性相关(检查属性、枚举属性等)_javascript技巧

JS对象属性相关(检查属性、枚举属性等)_javascript技巧

时间:2021-07-01 10:21:17 帮助过:10人阅读

1.删除属性

delete运算符可以删除对象的属性

代码如下:

delete person.age //即person不再有属性age
delete person['age'] //或者这样

delete只是断开属性和宿主对象的联系,而不会去操作属性中的属性 看到delete a.p之后b.x仍然为1

delete只能删除自有属性,不能删除继承属性(要删除继承属性必须从定义这个属性的原型对象上删除它,当然,这会影响到所有继承来自这个原型的对象)

当然了,可配置的属性才能用到delete
比如

2.检测属性

使用 “in"

in 运算符希望它的左操作数是一个字符串或者可以转换为字符串,希望它的右操作数是一个对象

使用hasOwnProperty()或者propertyIsEnumerable() --- 后者是前者的增强
顾明思议

只有检测到是自由属性并是可枚举的属性时,后者才返回true

当然,也可以直接用 ”!=="运算符判断

3.枚举属性

拓展1:

每个对象都有与之相关的原型(prototype)、类(class)、可扩展性(extensible)
要检测一个对象是否是另一个对象的原型(或处于原型链中),可以使用isPrototypeOf()方法

当然,isPrototypeOf()方法和instanceof运算符非常类似
instanceof运算符希望它的左操作数是一个对象,右操作数标识对象的类。如果左侧的对象是右侧类的实例,则表达式返回true,否则返回false

拓展2:

对象的类属性是一个字符串,用以表示对象的类型信息

一般调用toString()方法后返回形如 [object class]的形式

比如

代码如下:

var obj = {x:1,y:2};
console.log(obj.toString());//[object Object]

所以要想获取对象的类,就可以通过返回的字符串中找出 “class"字段 使用 slice(8,-1)
比如

人气教程排行