遍历对象是我们实际开发中经常用到的操作,今天就来做一个盘点。
: t9 [9 ^& @. ^! I2 N: v9 Z1 u, p3 `let obj = {name:"zhang",age:24,job:"程序员",hobby:["音乐","摄影","旅行"]}; 1、for...in遍历% ]$ A( s* O/ j6 G
for(let item in obj){
console.log(item); //item是对象属性名 name,age,job,hobby
} 2、Object.keys()' Q& b7 J& y8 h: p2 Q0 w% B/ K3 v
返回对象属性名组成的数组,然后就可以使用数组的遍历方法进行遍历。* Q7 N) @4 m# W' M& f3 I& b& i
Object.keys(obj); // ["name", "age", "job", "hobby"] 3、Object.getOwnPropertyNames()# N2 b: U4 e6 \! j" S2 R
返回对象属性名组成的数组1 |: G9 I, T- @0 R+ Q7 s. x
Object.getOwnPropertyNames(obj); // ["name", "age", "job", "hobby"] 4、Reflect.ownKeys()2 l% l& ?7 m& p0 I. L0 R
返回对象属性名组成的数组。Reflect是ES6为操作对象而提供的新API。提供了很多新的api用于替代旧的一些不友好的写法。
; [% d2 x) d+ c" x" IReflect.ownKeys(obj); // ["name", "age", "job", "hobby"]
|