遍历对象是我们实际开发中经常用到的操作,今天就来做一个盘点。8 E; t- \5 n. X" C
- let obj = {name:"zhang",age:24,job:"程序员",hobby:["音乐","摄影","旅行"]};
1、for...in遍历' T A& ?% G( \4 E3 i4 b& j
- for(let item in obj){
- console.log(item); //item是对象属性名 name,age,job,hobby
- }
2、Object.keys()
: G. e' `2 u8 K# J4 K3 Z1 @ A 返回对象属性名组成的数组,然后就可以使用数组的遍历方法进行遍历。
0 x5 J } c! D3 d. {- Object.keys(obj); // ["name", "age", "job", "hobby"]
3、Object.getOwnPropertyNames()
4 n! k- r% A: X0 U6 Z( h0 P 返回对象属性名组成的数组
- F( K2 R$ e9 ]. K* A- Object.getOwnPropertyNames(obj); // ["name", "age", "job", "hobby"]
4、Reflect.ownKeys()
) f; E2 z/ B' S8 A. a 返回对象属性名组成的数组。Reflect是ES6为操作对象而提供的新API。提供了很多新的api用于替代旧的一些不友好的写法。
. Y ~8 Y [$ V+ D" C# d- D: |- Reflect.ownKeys(obj); // ["name", "age", "job", "hobby"]
|