遍历对象是我们实际开发中经常用到的操作,今天就来做一个盘点。
4 O' o) [3 F5 [7 hlet obj = {name:"zhang",age:24,job:"程序员",hobby:["音乐","摄影","旅行"]}; 1、for...in遍历% H7 w+ _$ {6 K! `) D1 _9 B+ `3 X5 y
for(let item in obj){
console.log(item); //item是对象属性名 name,age,job,hobby
} 2、Object.keys()) `, x6 t' f5 z$ L6 i+ `4 |
返回对象属性名组成的数组,然后就可以使用数组的遍历方法进行遍历。
" c% V* Z3 ?# r0 [1 |Object.keys(obj); // ["name", "age", "job", "hobby"] 3、Object.getOwnPropertyNames()
6 g# l8 J: i7 _. B 返回对象属性名组成的数组8 x5 G! _+ T8 f8 k3 N9 u; c" r f
Object.getOwnPropertyNames(obj); // ["name", "age", "job", "hobby"] 4、Reflect.ownKeys()
9 i9 F+ }* D! K# I* {, M" e 返回对象属性名组成的数组。Reflect是ES6为操作对象而提供的新API。提供了很多新的api用于替代旧的一些不友好的写法。 Z3 X t2 ~$ T. q* S9 C; {; U' ~2 s
Reflect.ownKeys(obj); // ["name", "age", "job", "hobby"]
|