遍历对象是我们实际开发中经常用到的操作,今天就来做一个盘点。1 D7 h- _6 P. E2 y0 y4 U! e8 G
let obj = {name:"zhang",age:24,job:"程序员",hobby:["音乐","摄影","旅行"]}; 1、for...in遍历
: G$ z/ Q- `- j- R$ H1 Vfor(let item in obj){
console.log(item); //item是对象属性名 name,age,job,hobby
} 2、Object.keys()
- D7 ^/ V2 H4 T 返回对象属性名组成的数组,然后就可以使用数组的遍历方法进行遍历。5 W9 T6 G: a5 Q6 i1 q$ [
Object.keys(obj); // ["name", "age", "job", "hobby"] 3、Object.getOwnPropertyNames()
) x" ^) I- |* o1 n 返回对象属性名组成的数组. M, ~6 c# R* l4 N/ E
Object.getOwnPropertyNames(obj); // ["name", "age", "job", "hobby"] 4、Reflect.ownKeys()
7 h" {6 s9 U. r0 _9 q" R2 z/ M 返回对象属性名组成的数组。Reflect是ES6为操作对象而提供的新API。提供了很多新的api用于替代旧的一些不友好的写法。
; n6 p. o5 c) ^, m9 WReflect.ownKeys(obj); // ["name", "age", "job", "hobby"]
|