遍历对象是我们实际开发中经常用到的操作,今天就来做一个盘点。8 h8 C4 z+ u3 c* _* r! k
let obj = {name:"zhang",age:24,job:"程序员",hobby:["音乐","摄影","旅行"]}; 1、for...in遍历
! G* j; I0 B% S% Kfor(let item in obj){
console.log(item); //item是对象属性名 name,age,job,hobby
} 2、Object.keys()
" d- v: S) r% ~ 返回对象属性名组成的数组,然后就可以使用数组的遍历方法进行遍历。
p. `8 a: \+ \8 P, {, T* IObject.keys(obj); // ["name", "age", "job", "hobby"] 3、Object.getOwnPropertyNames()
' i' u1 T' o. j( \/ F) j 返回对象属性名组成的数组5 c7 U/ B% R6 B* p
Object.getOwnPropertyNames(obj); // ["name", "age", "job", "hobby"] 4、Reflect.ownKeys()
# B2 M9 ]/ l' r8 Z1 t3 h 返回对象属性名组成的数组。Reflect是ES6为操作对象而提供的新API。提供了很多新的api用于替代旧的一些不友好的写法。
1 ?/ [2 q% l s1 J+ B/ |. ~4 gReflect.ownKeys(obj); // ["name", "age", "job", "hobby"]
|