遍历对象是我们实际开发中经常用到的操作,今天就来做一个盘点。
& u4 ^2 A% n" ?4 g6 U8 o e4 Tlet obj = {name:"zhang",age:24,job:"程序员",hobby:["音乐","摄影","旅行"]}; 1、for...in遍历/ @4 w1 W' Y2 i* Q/ Q4 r
for(let item in obj){
console.log(item); //item是对象属性名 name,age,job,hobby
} 2、Object.keys()3 l# Q% o S2 e, m( j/ u
返回对象属性名组成的数组,然后就可以使用数组的遍历方法进行遍历。, |1 Y5 |5 E9 m
Object.keys(obj); // ["name", "age", "job", "hobby"] 3、Object.getOwnPropertyNames()
8 x# \/ X) i# O& g: c: u 返回对象属性名组成的数组
. e- {+ r- \( EObject.getOwnPropertyNames(obj); // ["name", "age", "job", "hobby"] 4、Reflect.ownKeys()* k9 f: v- s/ {
返回对象属性名组成的数组。Reflect是ES6为操作对象而提供的新API。提供了很多新的api用于替代旧的一些不友好的写法。 B4 j, G& b+ G
Reflect.ownKeys(obj); // ["name", "age", "job", "hobby"]
|