遍历对象是我们实际开发中经常用到的操作,今天就来做一个盘点。
+ W6 r6 Y/ D, C
- let obj = {name:"zhang",age:24,job:"程序员",hobby:["音乐","摄影","旅行"]};
1、for...in遍历
* R5 O! @+ {3 V, H5 ?0 D9 d- for(let item in obj){
- console.log(item); //item是对象属性名 name,age,job,hobby
- }
2、Object.keys()0 d0 R: L. c5 R( w; i( S! U
返回对象属性名组成的数组,然后就可以使用数组的遍历方法进行遍历。+ U& ?6 v, D4 q% R" j, w7 B7 X
- Object.keys(obj); // ["name", "age", "job", "hobby"]
3、Object.getOwnPropertyNames()4 F* s4 X, W1 U4 R1 I
返回对象属性名组成的数组
9 s1 u7 H7 m( z X- Object.getOwnPropertyNames(obj); // ["name", "age", "job", "hobby"]
4、Reflect.ownKeys()4 A0 ]. ]2 `& t
返回对象属性名组成的数组。Reflect是ES6为操作对象而提供的新API。提供了很多新的api用于替代旧的一些不友好的写法。
$ C/ d D* l- O" }1 R) I7 H- Reflect.ownKeys(obj); // ["name", "age", "job", "hobby"]
|