JS遍历对象属性的方法(可枚举和不可枚举的区别)

本文例举JavaScript中遍历对象属性的方法,文末介绍可枚举和不可枚举的区别。

JS遍历对象属性的常用方法:

  1. for...in 循环:用于遍历对象的可枚举属性,包括继承的属性。
const obj = {a: 1, b: 2, c: 3};

for (let key in obj) {
  console.log(key, obj[key]);
}
// 输出:
// a 1
// b 2
// c 3

注意:使用 for…in 循环时,可能会遍历到对象原型链上的属性,因此可以通过 hasOwnProperty 方法来过滤掉继承的属性

for (let key in obj) {
  if (obj.hasOwnProperty(key)) {
    console.log(key, obj[key]);
  }
}
  1. Object.keys() 方法:返回一个包含对象自身的可枚举属性(不包括继承的属性)的数组。
const obj = {a: 1, b: 2, c: 3};
const keys = Object.keys(obj);

for (let key of keys) {
  console.log(key, obj[key]);
}
// 输出:
// a 1
// b 2
// c 3
  1. Object.entries() 方法:返回一个包含对象自身的可枚举属性的键值对数组。
const obj = {a: 1, b: 2, c: 3};
const entries = Object.entries(obj);

for (let [key, value] of entries) {
  console.log(key, value);
}
// 输出:
// a 1
// b 2
// c 3
  1. Object.getOwnPropertyNames() 方法:返回一个包含对象自身的所有属性(包括不可枚举属性)的数组。
const obj = {a: 1, b: 2, c: 3};
const properties = Object.getOwnPropertyNames(obj);

for (let property of properties) {
  console.log(property, obj[property]);
}
// 输出:
// a 1
// b 2
// c 3

可枚举和不可枚举的区别:

在JavaScript中,每个对象属性都有一个属性描述符(property descriptor),其中之一就是enumerable(可枚举)属性。

可枚举属性是指那些可以通过对象属性枚举(例如通过 for…in 循环)访问到的属性。当一个属性是可枚举的时候,它将会被枚举出来,可以被遍历到。

不可枚举属性是指那些不能通过对象属性枚举访问到的属性。通常这些属性是一些内部属性,不会出现在通常的遍历中。例如,对象的内置方法(例如 Object.prototype.toString)的属性通常是不可枚举的。

默认情况下,通过字面量创建的对象的属性都是可枚举的,而通过构造函数创建的对象的属性通常是不可枚举的,但可以通过 Object.defineProperty() 或者类似的方法来定义为不可枚举的。

例如,下面的示例展示了可枚举属性和不可枚举属性的区别:

const obj = {
  a: 1,
  b: 2,
};

Object.defineProperty(obj, 'c', {
  value: 3,
  enumerable: false, // 将属性 c 定义为不可枚举
});

for (let key in obj) {
  console.log(key); // 输出: a 和 b,不包括 c
}

console.log(Object.keys(obj)); // 输出: ['a', 'b'],不包括 c
console.log(Object.getOwnPropertyNames(obj)); // 输出: ['a', 'b', 'c'],包括 c

在这个示例中,属性 c 被定义为不可枚举,因此它不会出现在 for…in 循环或者 Object.keys() 的结果中,但会出现在 Object.getOwnPropertyNames() 的结果中。

  • 3
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
JavaScript遍历对象属性方法有多种。其中,常用的方法有: 1. 使用for...in循环:for...in可以遍历对象的可枚举属性,包括原型链上的属性。可以通过判断hasOwnProperty方法来过滤掉原型链上的属性。例如: ```javascript let obj = {type: 1, keyword: "js"}; for (let key in obj) { if (obj.hasOwnProperty(key)) { console.log(key, obj[key]); } } ``` 2. 使用Object.keys()方法:Object.keys()返回一个由对象的可枚举属性组成的数组。可以遍历对象的可枚举属性,不包括原型链上的属性。例如: ```javascript let obj = {type: 1, keyword: "js"}; Object.keys(obj).forEach(key => console.log(key, obj[key])); ``` 3. 使用Object.getOwnPropertyNames()方法:Object.getOwnPropertyNames()返回一个由对象的所有属性(包括可枚举不可枚举属性)组成的数组。可以遍历对象的所有属性,不包括原型链上的属性。例如: ```javascript let obj = {type: 1, keyword: "js"}; Object.getOwnPropertyNames(obj).forEach(key => console.log(key, obj[key])); ``` 4. 使用Object.getOwnPropertySymbols()方法:Object.getOwnPropertySymbols()返回一个由对象的所有Symbol属性组成的数组。只能遍历对象的Symbol属性,不包括其他非Symbol属性。例如: ```javascript let obj = {type: 1, keyword: "js"}; Object.getOwnPropertySymbols(obj).forEach(key => console.log(key, obj[key])); ``` 这些方法可以根据需要选择使用,以实现对对象属性遍历。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [JS遍历对象属性的7种方式](https://blog.csdn.net/weixin_40895135/article/details/126584088)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *3* [JS——遍历对象方法总结](https://blog.csdn.net/weixin_49392771/article/details/123354161)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值