JavaScript中的可枚举属性与不可枚举属性
2021-07-11 00:07
标签:打印 javascrip 判断 obj var 基本 log col value https://www.cnblogs.com/kongxy/p/4618173.html 在JavaScript中,对象的属性分为可枚举和不可枚举之分,它们是由属性的enumerable值决定的。可枚举性决定了这个属性能否被for…in查找遍历到。 一、怎么判断属性是否可枚举 js中基本包装类型的原型属性是不可枚举的,如Object, Array, Number等,如果你写出这样的代码遍历其中的属性: 它的输出结果会是空。这是因为Number中内置的属性是不可枚举的,所以不能被for…in访问到。 Object对象的propertyIsEnumerable()方法可以判断此对象是否包含某个属性,并且这个属性是否可枚举。 需要注意的是:如果判断的属性存在于Object对象的原型内,不管它是否可枚举都会返回false。 二、枚举性的作用 属性的枚举性会影响以下三个函数的结果: for…in Object.keys() JSON.stringify 先看一个例子,按如下方法创建kxy对象: 其中用defineProperty为对象定义了一个名为”sex”的不可枚举属性 接下来做以下验证: 1. 遍历结果: kxy.name = KXY kxy.constructor = function Person() { 可以看到除了”sex“之外的属性都遍历到了 [ 个人补充 for(var pro in kxy) { kxy.name = KXY ] 2. 结果: 只包含”name”属性,说明该方法只能返回对象本身具有的可枚举属性。 3.
此方法也只能读取对象本身的可枚举属性,并序列化为JSON对象。 JavaScript中的可枚举属性与不可枚举属性 标签:打印 javascrip 判断 obj var 基本 log col value 原文地址:https://www.cnblogs.com/jcz1206/p/9553115.html
var
num =
new
Number();
for
(
var
pro
in
num) {
console.log(
"num."
+ pro +
" = "
+ num[pro]);
}
function
Person() {
this
.name =
"KXY"
;
}
Person.prototype = {
constructor: Person,
job:
"student"
,
};
var
kxy =
new
Person();
Object.defineProperty(kxy,
"sex"
, {
value:
"female"
,
enumerable:
false
});
for
(
var
pro
in
kxy) {
console.log(
"kxy."
+ pro +
" = "
+ kxy[pro]);
}
this.name = "KXY";
}
kxy.job = student
if(kxy.hasOwnProperty(pro)) console.log("kxy." + pro + " = " + kxy[pro]);
}
打印结果是:
console.log(Object.keys(kxy));
console.log(JSON.stringify(kxy));
上一篇:差分进化算法
下一篇:jQuery中$.fn