遍历对象是我们实际开发中经常用到的操作,今天就来做一个盘点。1 _. v- J5 a7 \ N! O/ f
let obj = {name:"zhang",age:24,job:"程序员",hobby:["音乐","摄影","旅行"]}; 1、for...in遍历
8 |6 p' q9 k# w% @8 _9 i3 Ofor(let item in obj){
console.log(item); //item是对象属性名 name,age,job,hobby
} 2、Object.keys()1 A4 I$ h6 R6 r
返回对象属性名组成的数组,然后就可以使用数组的遍历方法进行遍历。
( F/ o/ e/ \7 u$ m' KObject.keys(obj); // ["name", "age", "job", "hobby"] 3、Object.getOwnPropertyNames()
7 F0 T0 h2 D7 t) C0 f9 o% P P, ` 返回对象属性名组成的数组# d: M5 D: I) R2 @% J3 P
Object.getOwnPropertyNames(obj); // ["name", "age", "job", "hobby"] 4、Reflect.ownKeys()3 ~3 \' E8 Q( i6 s2 J, {4 O
返回对象属性名组成的数组。Reflect是ES6为操作对象而提供的新API。提供了很多新的api用于替代旧的一些不友好的写法。7 M: `3 f8 \7 b0 \# G& B9 D- e3 \
Reflect.ownKeys(obj); // ["name", "age", "job", "hobby"]
|