遍历对象是我们实际开发中经常用到的操作,今天就来做一个盘点。
+ q+ d$ S3 @0 _5 _let obj = {name:"zhang",age:24,job:"程序员",hobby:["音乐","摄影","旅行"]}; 1、for...in遍历9 K7 y# `% V# N+ b, P
for(let item in obj){
console.log(item); //item是对象属性名 name,age,job,hobby
} 2、Object.keys()
+ T9 |0 g5 W& S& k/ o5 J 返回对象属性名组成的数组,然后就可以使用数组的遍历方法进行遍历。8 y; A2 V2 ~% |6 |" {
Object.keys(obj); // ["name", "age", "job", "hobby"] 3、Object.getOwnPropertyNames()
4 O6 ?1 K- X$ L$ p7 c4 Y/ e3 A 返回对象属性名组成的数组
& a/ d4 V8 {: r m* P" W0 KObject.getOwnPropertyNames(obj); // ["name", "age", "job", "hobby"] 4、Reflect.ownKeys()
- S& @/ O h0 G% Y6 h3 H7 O; b 返回对象属性名组成的数组。Reflect是ES6为操作对象而提供的新API。提供了很多新的api用于替代旧的一些不友好的写法。
6 T+ p5 D" ~0 F( Z p4 g1 ~, x8 jReflect.ownKeys(obj); // ["name", "age", "job", "hobby"]
|