遍历对象是我们实际开发中经常用到的操作,今天就来做一个盘点。0 A m9 O+ {+ Y' A+ N2 Q
let obj = {name:"zhang",age:24,job:"程序员",hobby:["音乐","摄影","旅行"]}; 1、for...in遍历
4 w3 \ a9 L" Q1 Q! E$ V; \for(let item in obj){
console.log(item); //item是对象属性名 name,age,job,hobby
} 2、Object.keys()
) F8 [: \5 h6 f6 q" p 返回对象属性名组成的数组,然后就可以使用数组的遍历方法进行遍历。, A- Q. J7 Y& [$ C
Object.keys(obj); // ["name", "age", "job", "hobby"] 3、Object.getOwnPropertyNames()7 Q8 u& y( i; O% s M
返回对象属性名组成的数组* }7 w, p, V9 Z7 G5 Y
Object.getOwnPropertyNames(obj); // ["name", "age", "job", "hobby"] 4、Reflect.ownKeys()$ i5 O3 @- |, U
返回对象属性名组成的数组。Reflect是ES6为操作对象而提供的新API。提供了很多新的api用于替代旧的一些不友好的写法。/ d- q: }# R8 K9 Z% ~
Reflect.ownKeys(obj); // ["name", "age", "job", "hobby"]
|