遍历对象是我们实际开发中经常用到的操作,今天就来做一个盘点。
" J' y9 e5 f0 ~3 W' Q4 \let obj = {name:"zhang",age:24,job:"程序员",hobby:["音乐","摄影","旅行"]}; 1、for...in遍历
6 Z2 ]0 B t% J5 v/ i/ yfor(let item in obj){
console.log(item); //item是对象属性名 name,age,job,hobby
} 2、Object.keys()5 d3 y6 q$ e( F, l; K) a9 y) C
返回对象属性名组成的数组,然后就可以使用数组的遍历方法进行遍历。$ Z7 r, a i, j5 u6 U( H2 T7 v
Object.keys(obj); // ["name", "age", "job", "hobby"] 3、Object.getOwnPropertyNames()' H& W8 }* Q" S0 V, F- ]8 e* R! g
返回对象属性名组成的数组- ?! D' E; s; D3 |/ }9 |
Object.getOwnPropertyNames(obj); // ["name", "age", "job", "hobby"] 4、Reflect.ownKeys()2 w) X- q D9 X3 `+ \
返回对象属性名组成的数组。Reflect是ES6为操作对象而提供的新API。提供了很多新的api用于替代旧的一些不友好的写法。4 q0 p: I+ D. e* F
Reflect.ownKeys(obj); // ["name", "age", "job", "hobby"]
|