遍历对象是我们实际开发中经常用到的操作,今天就来做一个盘点。
; |: H7 j5 b; A! plet obj = {name:"zhang",age:24,job:"程序员",hobby:["音乐","摄影","旅行"]}; 1、for...in遍历
2 |1 \8 E: S! T" A4 p4 `for(let item in obj){
console.log(item); //item是对象属性名 name,age,job,hobby
} 2、Object.keys()
, G: Y# r7 D+ _ 返回对象属性名组成的数组,然后就可以使用数组的遍历方法进行遍历。
8 X. ^) N) ?" u) S, T6 qObject.keys(obj); // ["name", "age", "job", "hobby"] 3、Object.getOwnPropertyNames()
- V9 ?% P6 ?1 v0 p' c6 ` 返回对象属性名组成的数组
4 A$ }% B* |4 U( p4 G1 cObject.getOwnPropertyNames(obj); // ["name", "age", "job", "hobby"] 4、Reflect.ownKeys()
' m! \: W0 G. d 返回对象属性名组成的数组。Reflect是ES6为操作对象而提供的新API。提供了很多新的api用于替代旧的一些不友好的写法。, m. z! z! i1 [
Reflect.ownKeys(obj); // ["name", "age", "job", "hobby"]
|