JavaScript中的可枚举属性与不可枚举属性
来源:互联网 发布:苹果屏幕录像软件 编辑:程序博客网 时间:2024/06/08 13:15
在JavaScript中,对象的属性分为可枚举和不可枚举之分,它们是由属性的enumerable值决定的。可枚举性决定了这个属性能否被for…in查找遍历到。
一、怎么判断属性是否可枚举
js中基本包装类型的原型属性是不可枚举的,如Object, Array, Number等,如果你写出这样的代码遍历其中的属性:
1
2
3
4
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对象:
1
2
3
4
5
6
7
8
9
10
11
12
13
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”的不可枚举属性
接下来做以下验证:
1.
1
2
3
for
(
var
pro
in
kxy) {
console.log(
"kxy."
+ pro +
" = "
+ kxy[pro]);
}
遍历结果:
可以看到除了”sex“之外的属性都遍历到了
2.
1
console.log(Object.keys(kxy));
结果:
只包含”name”属性,说明该方法只能返回对象本身具有的可枚举属性。
3.
1
console.log(JSON.stringify(kxy));
<结果:
此方法也只能读取对象本身的可枚举属性,并序列化为JSON对象。
0 0
- JavaScript中的可枚举属性与不可枚举属性
- javascript中的可枚举属性与不可枚举属性
- 可枚举属性和不可枚举属性
- 对象可枚举和不可枚举属性
- 枚举属性和不可枚举属性
- es6 javascript属性的可枚举性
- javascript 中的index()属性与lastIndex()属性
- JS 对象属性"可枚举"
- 前端复习--对象的可枚举属性
- JavaScript的继承、检测属性、属性特性、枚举属性
- 理解Javascript对象(属性探测,删除属性,属性枚举)
- javascript中的location属性
- JavaScript中的prototype属性
- javascript中的event属性
- Javascript 中的 Prototype属性
- JavaScript中的prototype属性
- JavaScript中的对象属性
- javascript中的prototype属性
- Chart.js Uncaught ReferenceError: require is not defined
- 揭秘360手机助手未经用户同意,自动开启辅助功能的“黑科技”
- yii2->验证码问题(Yii2.0 ajax验证,验证码报错,load方法)
- Hibernate
- git 上传代码
- JavaScript中的可枚举属性与不可枚举属性
- TCL学习之字符串函数
- 数据库(第一范式,第二范式,第三范式)
- c/c++学习 No.3 ctype.h的使用
- java中String类和StringBuffer类实例详解
- log4j日志文件乱码问题的解决方法
- Romantic
- # 使用scp从windows拷贝文件到linux服务器 scp(security copy protocol)
- 编译ffmpeg无法生成ffplay的问题解决