【js】对象的遍历方法总结


一、对象常用遍历方式

 	for...in
    Object.keys()
    Object.getOwnPropertyNames()
    Object.getOwnPropertySymbols()
    Reflect.ownKeys()

二、对象的属性分类和Symbol属性

1.对象的属性分类

  • 原型属性
  • 对象自身的可以枚举属性
  • 对象自身的不可枚举属性
  • symbol属性
// 注意: Object.create是利用给定的对象作为原型对象进行创建新的对象
const obj = Object.create({
    bar: 'bar'// 原型属性
});
obj.foo = 'foo';// 对象的自身可枚举属性
Object.defineProperty(obj, 'name', {// 对象自身不可枚举的属性
    enumerable: false,
    value: 'kongs'
});
obj[Symbol('age')] = 'age'; // 对象的symbol属性

2.关于Symbol属性的拓展

代码如下(示例):

1、let a = Symbol('a'), 创建symbol实例是不能用new创建的
2、具有相同描述的symbol实例是不相等的, Symbpl('b') != Symbol('b')
3、如果想得到同一个描述的相等的两个symbol,可以这样:Symbol.for('c') == Symbol.for('c')

三、对象的遍历方法说明

1.for…in循环

  • 该方法是可以获取对象自身的可枚举属性 + 原型链上的可以枚举属性,但是不含symbol属性
// 3.1
for(let key in obj) {
   console.log(key)
};
// 结果会输出: bar foo



// 3.2 如果想过滤掉原型上的属性可以这样:
for(let key in obj) {
   if (obj.hasOwnProperty(key)) {
       console.log(key)
   }
};
// 结果会输出:  foo

// 3.3 for..in的输出顺序:
// 对于大于等于0的整数,会按照大小进行排序, 对于小数和负数就会当作字符串处理
// 对于string类型,按照第一的顺序进行输出
// symbol属性将被过滤掉,不会输出

const obj2 = {
   5: '5',
   a: 'a',
   1: '1',
   c: 'c',
   '-1': '-1',
   '3': '3',
   b: 'b'
}
for(let key in obj2) {
   console.log(key);
}

// 结果会输出:  1 3 5  a c -1 b

2.Object.keys()方法

  • 该方法获取对象自身的可枚举属性
  • 不包含原型上的可枚举属性和symbol属性
  • es5新增
Object.keys(obj).forEach(key =>  console.log(key)) // 输出: foo

3.Object.getOwnPropertyNames()方法

  • 该方法获取对象自身的所有属性,包括不可枚举属性
  • 但是不包含原型属性和symbol属性
  • es5新增
Object.getOwnPropertyNames(obj).forEach(i => console.log(i))// 输出: foo name
// 拓展:如何判断属性是否可以枚举?
//方法一:
 Object.getOwnPropertyDescriptor(obj, 'name')
//方法二:
Object.prototype.propertyIsEnumerable.call(obj, ['name'])

4.Object.getOwnPropertySymbols()方法

  • 该方法获取对象自身所有的symbol属性
  • 不包括原型上的symbol属性
  • es6新增
Object.getOwnPropertySymbols(obj).forEach(i => console.log(i));// 输出: Symbol(age)

5.Reflect.ownKeys()方法

  • 该方法获取对象自身的所有属性,包括不可枚举和symbol属性
  • es6新增
Reflect.ownKeys(obj).forEach(i => console.log(i)); // 输出: foo name Symbol(age)
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 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
发出的红包

打赏作者

LuckyCola2023

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值