遍历对象是我们实际开发中经常用到的操作,今天就来做一个盘点。
% j/ K' i# e* i! u, ~ ^; D) llet obj = {name:"zhang",age:24,job:"程序员",hobby:["音乐","摄影","旅行"]}; 1、for...in遍历* ]# I7 _; y- [' w$ {6 d+ N
for(let item in obj){
console.log(item); //item是对象属性名 name,age,job,hobby
} 2、Object.keys()) F. A5 C9 [" J. A% f! t& j) p
返回对象属性名组成的数组,然后就可以使用数组的遍历方法进行遍历。
6 [5 N# [% J- m6 a E& \; D" e2 eObject.keys(obj); // ["name", "age", "job", "hobby"] 3、Object.getOwnPropertyNames()
. O8 F$ H5 @* S$ L( } 返回对象属性名组成的数组
: W0 p. E# |0 q( k/ eObject.getOwnPropertyNames(obj); // ["name", "age", "job", "hobby"] 4、Reflect.ownKeys()
: @9 q) |" q7 F. f5 v3 y3 M 返回对象属性名组成的数组。Reflect是ES6为操作对象而提供的新API。提供了很多新的api用于替代旧的一些不友好的写法。! S w$ L: l" n3 c8 E* f
Reflect.ownKeys(obj); // ["name", "age", "job", "hobby"]
|