遍历对象是我们实际开发中经常用到的操作,今天就来做一个盘点。8 ]5 [1 r0 X, C9 V j# [
let obj = {name:"zhang",age:24,job:"程序员",hobby:["音乐","摄影","旅行"]}; 1、for...in遍历
/ d+ @: Q5 t% H1 B, s+ r U8 u" Hfor(let item in obj){
console.log(item); //item是对象属性名 name,age,job,hobby
} 2、Object.keys()9 }# c7 F+ O, |1 b* h) q2 \
返回对象属性名组成的数组,然后就可以使用数组的遍历方法进行遍历。. _, S& `2 p9 f4 \8 ?; R4 b
Object.keys(obj); // ["name", "age", "job", "hobby"] 3、Object.getOwnPropertyNames()
! `7 b) B) s0 f& z5 I$ _ 返回对象属性名组成的数组
+ ^: }. l) |; K a2 g( r; \Object.getOwnPropertyNames(obj); // ["name", "age", "job", "hobby"] 4、Reflect.ownKeys()
2 F; H F$ m1 T! T0 g' s 返回对象属性名组成的数组。Reflect是ES6为操作对象而提供的新API。提供了很多新的api用于替代旧的一些不友好的写法。
l: {$ c6 C1 W" FReflect.ownKeys(obj); // ["name", "age", "job", "hobby"]
|