遍历对象是我们实际开发中经常用到的操作,今天就来做一个盘点。
* L+ P2 q& D, F; [! vlet obj = {name:"zhang",age:24,job:"程序员",hobby:["音乐","摄影","旅行"]}; 1、for...in遍历! g' u; N% l* J7 ^ j4 }! Y* [; S. w
for(let item in obj){
console.log(item); //item是对象属性名 name,age,job,hobby
} 2、Object.keys()
" n8 _# V; g, f 返回对象属性名组成的数组,然后就可以使用数组的遍历方法进行遍历。: D; X/ C9 t) q2 B) u; K1 O' T
Object.keys(obj); // ["name", "age", "job", "hobby"] 3、Object.getOwnPropertyNames()
1 \; _* Q- J3 a' e: { 返回对象属性名组成的数组5 u; T( T( B) H y. s5 ~" q
Object.getOwnPropertyNames(obj); // ["name", "age", "job", "hobby"] 4、Reflect.ownKeys()
' c* ]+ ]" t5 v& j6 J' n: z 返回对象属性名组成的数组。Reflect是ES6为操作对象而提供的新API。提供了很多新的api用于替代旧的一些不友好的写法。8 F- ]2 L2 z: j
Reflect.ownKeys(obj); // ["name", "age", "job", "hobby"]
|