遍历对象是我们实际开发中经常用到的操作,今天就来做一个盘点。3 f; m% y) H3 s
let obj = {name:"zhang",age:24,job:"程序员",hobby:["音乐","摄影","旅行"]}; 1、for...in遍历5 ]+ I/ z' x1 S }" Z: }
for(let item in obj){
console.log(item); //item是对象属性名 name,age,job,hobby
} 2、Object.keys()
' x; ~3 H3 [( _2 Q/ U 返回对象属性名组成的数组,然后就可以使用数组的遍历方法进行遍历。! K8 w. Z; k+ r/ o% h) q0 [
Object.keys(obj); // ["name", "age", "job", "hobby"] 3、Object.getOwnPropertyNames() O3 v0 m1 f. l7 @6 {4 g: n1 w
返回对象属性名组成的数组
0 I$ G( H; m- g' p8 ~* YObject.getOwnPropertyNames(obj); // ["name", "age", "job", "hobby"] 4、Reflect.ownKeys()- P: Q/ i/ A% n% M1 ]
返回对象属性名组成的数组。Reflect是ES6为操作对象而提供的新API。提供了很多新的api用于替代旧的一些不友好的写法。
* N1 e: g0 p& ?Reflect.ownKeys(obj); // ["name", "age", "job", "hobby"]
|