遍历对象是我们实际开发中经常用到的操作,今天就来做一个盘点。
3 [# n; k% N, {3 O( \5 i+ T ]( Llet obj = {name:"zhang",age:24,job:"程序员",hobby:["音乐","摄影","旅行"]}; 1、for...in遍历/ l7 {# b% @ j% F
for(let item in obj){
console.log(item); //item是对象属性名 name,age,job,hobby
} 2、Object.keys()1 p; q- |. C. q( B* e$ W; Y
返回对象属性名组成的数组,然后就可以使用数组的遍历方法进行遍历。( G( `, ~$ ^' ?
Object.keys(obj); // ["name", "age", "job", "hobby"] 3、Object.getOwnPropertyNames(); j- |7 w' x2 W" ]
返回对象属性名组成的数组" n% w7 U6 O: G; d
Object.getOwnPropertyNames(obj); // ["name", "age", "job", "hobby"] 4、Reflect.ownKeys(): d& @1 C; Z0 T7 m, ]0 ~; F% ?
返回对象属性名组成的数组。Reflect是ES6为操作对象而提供的新API。提供了很多新的api用于替代旧的一些不友好的写法。3 N! W& p2 o3 k" W
Reflect.ownKeys(obj); // ["name", "age", "job", "hobby"]
|