遍历对象是我们实际开发中经常用到的操作,今天就来做一个盘点。
& d( I# g" q! r" wlet obj = {name:"zhang",age:24,job:"程序员",hobby:["音乐","摄影","旅行"]}; 1、for...in遍历
8 l) p$ Y1 I$ ], A/ z/ qfor(let item in obj){
console.log(item); //item是对象属性名 name,age,job,hobby
} 2、Object.keys(): g0 @* O7 j9 i
返回对象属性名组成的数组,然后就可以使用数组的遍历方法进行遍历。
# D. d$ R' _( a K6 q9 UObject.keys(obj); // ["name", "age", "job", "hobby"] 3、Object.getOwnPropertyNames()
, L# I6 _+ e/ s5 A/ X- K Z2 D# l 返回对象属性名组成的数组
9 P# y1 \& \1 tObject.getOwnPropertyNames(obj); // ["name", "age", "job", "hobby"] 4、Reflect.ownKeys()0 m" C; W' [: W" K* Y3 W6 A
返回对象属性名组成的数组。Reflect是ES6为操作对象而提供的新API。提供了很多新的api用于替代旧的一些不友好的写法。" C% e: Z2 n! f5 i
Reflect.ownKeys(obj); // ["name", "age", "job", "hobby"]
|