遍历对象是我们实际开发中经常用到的操作,今天就来做一个盘点。
% C$ F- c8 o/ Ilet obj = {name:"zhang",age:24,job:"程序员",hobby:["音乐","摄影","旅行"]}; 1、for...in遍历
. _& a$ \1 U) @. G3 k: l$ B" j' t6 hfor(let item in obj){
console.log(item); //item是对象属性名 name,age,job,hobby
} 2、Object.keys()5 E: c/ ^1 @. Y- s& d
返回对象属性名组成的数组,然后就可以使用数组的遍历方法进行遍历。: X3 M& t/ ~5 k; W
Object.keys(obj); // ["name", "age", "job", "hobby"] 3、Object.getOwnPropertyNames()
1 r+ f4 V2 b8 h5 U3 t0 H, e 返回对象属性名组成的数组
1 d* \- z1 S# |1 }4 Y/ C- TObject.getOwnPropertyNames(obj); // ["name", "age", "job", "hobby"] 4、Reflect.ownKeys()- D0 H6 g9 T' J% F+ ]9 D2 D1 J# |
返回对象属性名组成的数组。Reflect是ES6为操作对象而提供的新API。提供了很多新的api用于替代旧的一些不友好的写法。. y$ t- q5 G1 X+ [
Reflect.ownKeys(obj); // ["name", "age", "job", "hobby"]
|