遍历对象是我们实际开发中经常用到的操作,今天就来做一个盘点。
3 \# }3 e- L! F6 A/ y0 B* ~let obj = {name:"zhang",age:24,job:"程序员",hobby:["音乐","摄影","旅行"]}; 1、for...in遍历
* z+ }* U( F8 x2 U, ?& d2 g) `for(let item in obj){
console.log(item); //item是对象属性名 name,age,job,hobby
} 2、Object.keys()
) h& i+ i& K9 @5 q+ M( ` 返回对象属性名组成的数组,然后就可以使用数组的遍历方法进行遍历。
0 |/ \& [: E' U. H) `Object.keys(obj); // ["name", "age", "job", "hobby"] 3、Object.getOwnPropertyNames()
0 D5 j! q9 x f& H+ b, s9 W3 z 返回对象属性名组成的数组" i! C; H* J7 B1 |% G' e" x
Object.getOwnPropertyNames(obj); // ["name", "age", "job", "hobby"] 4、Reflect.ownKeys()8 t# |* k. M n0 d! A& z
返回对象属性名组成的数组。Reflect是ES6为操作对象而提供的新API。提供了很多新的api用于替代旧的一些不友好的写法。3 b. i! x9 R S6 ?: s- ]4 ^5 o/ ~
Reflect.ownKeys(obj); // ["name", "age", "job", "hobby"]
|