遍历对象是我们实际开发中经常用到的操作,今天就来做一个盘点。
/ u) \. C8 h0 h" u7 U8 t- Plet obj = {name:"zhang",age:24,job:"程序员",hobby:["音乐","摄影","旅行"]}; 1、for...in遍历
, Y# Q$ z) K# ^/ w# zfor(let item in obj){
console.log(item); //item是对象属性名 name,age,job,hobby
} 2、Object.keys()
3 E- F2 D: ]6 b1 h9 G! W9 Z 返回对象属性名组成的数组,然后就可以使用数组的遍历方法进行遍历。: E0 n3 I1 l5 w) X7 Q# j. A4 J9 ]8 j
Object.keys(obj); // ["name", "age", "job", "hobby"] 3、Object.getOwnPropertyNames()
1 v$ H5 B$ o$ F3 P1 s 返回对象属性名组成的数组
9 p- M% o) C+ @Object.getOwnPropertyNames(obj); // ["name", "age", "job", "hobby"] 4、Reflect.ownKeys()
6 U: Z4 D0 f( w6 v9 l& I 返回对象属性名组成的数组。Reflect是ES6为操作对象而提供的新API。提供了很多新的api用于替代旧的一些不友好的写法。
1 ?9 M& V- l. V) I7 _% d4 b$ sReflect.ownKeys(obj); // ["name", "age", "job", "hobby"]
|