遍历对象是我们实际开发中经常用到的操作,今天就来做一个盘点。
, C) L; P1 \8 Rlet obj = {name:"zhang",age:24,job:"程序员",hobby:["音乐","摄影","旅行"]}; 1、for...in遍历7 o% |# o$ g& j1 ]( O
for(let item in obj){
console.log(item); //item是对象属性名 name,age,job,hobby
} 2、Object.keys()
, v" H, b; f3 E8 G9 T 返回对象属性名组成的数组,然后就可以使用数组的遍历方法进行遍历。# w1 T; R3 c0 S3 u, U! A
Object.keys(obj); // ["name", "age", "job", "hobby"] 3、Object.getOwnPropertyNames()
0 ]7 k, X& \5 l- M 返回对象属性名组成的数组/ i" v. b# o" \3 U' `4 u
Object.getOwnPropertyNames(obj); // ["name", "age", "job", "hobby"] 4、Reflect.ownKeys()
3 K1 e5 j+ L: N4 [ 返回对象属性名组成的数组。Reflect是ES6为操作对象而提供的新API。提供了很多新的api用于替代旧的一些不友好的写法。
- V. k+ s: Q5 x8 U4 t, v! RReflect.ownKeys(obj); // ["name", "age", "job", "hobby"]
|