遍历对象是我们实际开发中经常用到的操作,今天就来做一个盘点。; U4 Y1 q- J9 [8 R" {7 E
let obj = {name:"zhang",age:24,job:"程序员",hobby:["音乐","摄影","旅行"]}; 1、for...in遍历 h$ x! V% P, R N! b
for(let item in obj){
console.log(item); //item是对象属性名 name,age,job,hobby
} 2、Object.keys()
: f: k) ]! [+ d4 D' q J* v 返回对象属性名组成的数组,然后就可以使用数组的遍历方法进行遍历。4 B6 C M. q% V3 {+ S; h' e0 k, L, H
Object.keys(obj); // ["name", "age", "job", "hobby"] 3、Object.getOwnPropertyNames()) P4 v8 ^% ~% U6 v; ]; P; ]
返回对象属性名组成的数组+ a0 I; | @4 ~ O' i K/ H6 @
Object.getOwnPropertyNames(obj); // ["name", "age", "job", "hobby"] 4、Reflect.ownKeys()
8 l( `' k/ w) ?2 T 返回对象属性名组成的数组。Reflect是ES6为操作对象而提供的新API。提供了很多新的api用于替代旧的一些不友好的写法。
' m" v( @2 b2 l/ ~6 a# kReflect.ownKeys(obj); // ["name", "age", "job", "hobby"]
|