通过实例解析js可枚举属性与不可枚举属性
2020-12-09 04:07
1401 查看
在JavaScript中,对象的属性分为可枚举和不可枚举之分,它们是由属性的enumerable值决定的。可枚举性决定了这个属性能否被for…in查找遍历到。
一、怎么判断属性是否可枚举
js中基本包装类型的原型属性是不可枚举的,如Object, Array, Number等,如果你写出这样的代码遍历其中的属性:
var num = new Number(); for(var pro in num) { console.log("num." + pro + " = " + num[pro]); }
它的输出结果会是空。这是因为Number中内置的属性是不可枚举的,所以不能被for…in访问到。
Object对象的propertyIsEnumerable()方法可以判断此对象是否包含某个属性,并且这个属性是否可枚举。
需要注意的是:如果判断的属性存在于Object对象的原型内,不管它是否可枚举都会返回false。
二、枚举性的作用
属性的枚举性会影响以下三个函数的结果:
- for…in
- Object.keys()
- JSON.stringify
先看一个例子,按如下方法创建kxy对象:
function Person() { this.name = "KXY"; } Person.prototype = { constructor: Person, job: "student", }; var kxy = new Person(); Object.defineProperty(kxy, "sex", { value: "female", enumerable: false });
其中用defineProperty为对象定义了一个名为”sex”的不可枚举属性
接下来做以下验证:
for(var pro in kxy) { console.log("kxy." + pro + " = " + kxy[pro]); }
遍历结果:
可以看到除了”sex“之外的属性都遍历到了
console.log(Object.keys(kxy));
结果:
只包含”name”属性,说明该方法只能返回对象本身具有的可枚举属性。
console.log(JSON.stringify(kxy));
结果:
此方法也只能读取对象本身的可枚举属性,并序列化为JSON对象。
以上就是本文的全部内容,希望对大家的学习有所帮助
您可能感兴趣的文章:相关文章推荐
- 通过枚举属性获得枚举实例
- JS中的可枚举属性与不可枚举属性
- 通过实例解析js简易模块加载器
- JS 操作Array数组的方法及属性实例解析
- JS函数内部属性之arguments和this实例解析
- JS 操作Array数组的方法及属性实例解析
- JS基础篇--JS中的可枚举属性与不可枚举属性以及扩展
- IE8对JS通过属性和数组遍历解析不一样的地方探讨
- This其实不难,通过实例全面解析JS中的This
- IE8对JS通过属性和数组遍历解析不一样的地方探讨
- 详解通过源码解析Node.js中cluster模块的主要功能实现
- [ JAVA ] 通过反射动态解析实例对象
- 每日一个js实例3-不同格式json解析
- js面向对象之静态方法和静态属性实例分析
- JS中可枚举属性(enumerable)和propertyIsEnumerable()
- js动态调用css属性的小规律及实例说明
- 80 - tree.js 笔记 -通过 AnimationMixer混合器解析骨骼动画
- js通过Base64 解析html,后台返回的加密字符串
- C#属性(Attribute)用法实例解析
- js中作用域的实例解析