遍历对象是我们实际开发中经常用到的操作,今天就来做一个盘点。
8 j+ R7 g2 v! j; }% d0 w% Vlet obj = {name:"zhang",age:24,job:"程序员",hobby:["音乐","摄影","旅行"]}; 1、for...in遍历8 J$ I0 I. G$ F. _
for(let item in obj){
console.log(item); //item是对象属性名 name,age,job,hobby
} 2、Object.keys()
0 W5 I' B: @, C$ j( _8 Q 返回对象属性名组成的数组,然后就可以使用数组的遍历方法进行遍历。
+ t5 q7 P2 S+ @6 i" ^# ?0 Z$ b% h$ [Object.keys(obj); // ["name", "age", "job", "hobby"] 3、Object.getOwnPropertyNames()
, } X# X& f! n5 ?, A$ l 返回对象属性名组成的数组
* `, C& n8 N& j' X! l# ~7 AObject.getOwnPropertyNames(obj); // ["name", "age", "job", "hobby"] 4、Reflect.ownKeys()
, M- ], g5 p: c# r) q$ i$ T 返回对象属性名组成的数组。Reflect是ES6为操作对象而提供的新API。提供了很多新的api用于替代旧的一些不友好的写法。
2 l" L3 M% x. l+ @Reflect.ownKeys(obj); // ["name", "age", "job", "hobby"]
|