遍历对象是我们实际开发中经常用到的操作,今天就来做一个盘点。
! k& t J! B1 ]; e) Slet obj = {name:"zhang",age:24,job:"程序员",hobby:["音乐","摄影","旅行"]}; 1、for...in遍历
$ b! c: |& q( ^+ t" l* Xfor(let item in obj){
console.log(item); //item是对象属性名 name,age,job,hobby
} 2、Object.keys()
5 B, A" ?; p) Z& b% g; x8 a 返回对象属性名组成的数组,然后就可以使用数组的遍历方法进行遍历。. A9 f W+ @2 w+ w
Object.keys(obj); // ["name", "age", "job", "hobby"] 3、Object.getOwnPropertyNames()
2 d: Y" T, R0 c( i5 C" E; E 返回对象属性名组成的数组
4 L: E- L, |' x' O+ L; gObject.getOwnPropertyNames(obj); // ["name", "age", "job", "hobby"] 4、Reflect.ownKeys()
# r3 R8 [- ^4 o5 a 返回对象属性名组成的数组。Reflect是ES6为操作对象而提供的新API。提供了很多新的api用于替代旧的一些不友好的写法。# `1 V, n( [1 ^3 o6 Y6 r0 Z
Reflect.ownKeys(obj); // ["name", "age", "job", "hobby"]
|