遍历对象是我们实际开发中经常用到的操作,今天就来做一个盘点。
! X h4 T/ J* j3 Clet obj = {name:"zhang",age:24,job:"程序员",hobby:["音乐","摄影","旅行"]}; 1、for...in遍历9 a9 `' d! T) Y s7 B* J
for(let item in obj){
console.log(item); //item是对象属性名 name,age,job,hobby
} 2、Object.keys()
, b K4 X3 S/ v, b( s- |9 X 返回对象属性名组成的数组,然后就可以使用数组的遍历方法进行遍历。
# q; p7 A X) K! \Object.keys(obj); // ["name", "age", "job", "hobby"] 3、Object.getOwnPropertyNames()
1 o5 Z/ K e8 S) o 返回对象属性名组成的数组6 l$ l5 s7 X, H @
Object.getOwnPropertyNames(obj); // ["name", "age", "job", "hobby"] 4、Reflect.ownKeys(). X. g: W% ]' q. _: s
返回对象属性名组成的数组。Reflect是ES6为操作对象而提供的新API。提供了很多新的api用于替代旧的一些不友好的写法。8 |* [: Y5 R; [, G Q. y, c
Reflect.ownKeys(obj); // ["name", "age", "job", "hobby"]
|