遍历对象是我们实际开发中经常用到的操作,今天就来做一个盘点。
' t3 |, n+ K- E' hlet obj = {name:"zhang",age:24,job:"程序员",hobby:["音乐","摄影","旅行"]}; 1、for...in遍历7 E i- p) Q% J
for(let item in obj){
console.log(item); //item是对象属性名 name,age,job,hobby
} 2、Object.keys()
: f s; i1 M6 }. J( G( Y 返回对象属性名组成的数组,然后就可以使用数组的遍历方法进行遍历。7 n3 f3 i9 B* j
Object.keys(obj); // ["name", "age", "job", "hobby"] 3、Object.getOwnPropertyNames()( }: W: M# R& M! o# k+ H$ [0 |& M
返回对象属性名组成的数组5 A. c' W/ u6 W4 N* r
Object.getOwnPropertyNames(obj); // ["name", "age", "job", "hobby"] 4、Reflect.ownKeys()
0 G8 o+ e+ A$ X) J* Z! Q2 }" { 返回对象属性名组成的数组。Reflect是ES6为操作对象而提供的新API。提供了很多新的api用于替代旧的一些不友好的写法。
+ w0 u, B( `$ v# v1 T9 U) mReflect.ownKeys(obj); // ["name", "age", "job", "hobby"]
|