遍历对象是我们实际开发中经常用到的操作,今天就来做一个盘点。8 f3 t2 ~8 l l7 B9 E
let obj = {name:"zhang",age:24,job:"程序员",hobby:["音乐","摄影","旅行"]}; 1、for...in遍历2 B9 ?# V: ?& @- ^( Y
for(let item in obj){
console.log(item); //item是对象属性名 name,age,job,hobby
} 2、Object.keys()
$ N1 P; Z/ z+ w% r8 `" } 返回对象属性名组成的数组,然后就可以使用数组的遍历方法进行遍历。
, e6 X8 R6 z" B1 A+ g1 pObject.keys(obj); // ["name", "age", "job", "hobby"] 3、Object.getOwnPropertyNames()
" H3 M8 M7 M. T5 K, a" d! F, \' u 返回对象属性名组成的数组
# n: Z/ Z$ o. \$ C; QObject.getOwnPropertyNames(obj); // ["name", "age", "job", "hobby"] 4、Reflect.ownKeys()0 O) r5 D3 V: O% h
返回对象属性名组成的数组。Reflect是ES6为操作对象而提供的新API。提供了很多新的api用于替代旧的一些不友好的写法。3 g! t1 m3 i! a' I4 H
Reflect.ownKeys(obj); // ["name", "age", "job", "hobby"]
|