遍历对象是我们实际开发中经常用到的操作,今天就来做一个盘点。
+ j% C) _# r. }* W- k! g" Klet obj = {name:"zhang",age:24,job:"程序员",hobby:["音乐","摄影","旅行"]}; 1、for...in遍历
" M( \" c1 ^& @9 C3 Cfor(let item in obj){
console.log(item); //item是对象属性名 name,age,job,hobby
} 2、Object.keys()
; O" u* Q9 ]) _( Z2 U 返回对象属性名组成的数组,然后就可以使用数组的遍历方法进行遍历。' I& u* `( Q" `; j3 L) v
Object.keys(obj); // ["name", "age", "job", "hobby"] 3、Object.getOwnPropertyNames()
% n3 K: L2 S4 [9 @8 X/ C$ N 返回对象属性名组成的数组
0 M- x) `$ y) m& ]8 EObject.getOwnPropertyNames(obj); // ["name", "age", "job", "hobby"] 4、Reflect.ownKeys()
0 v9 Z& s f4 S 返回对象属性名组成的数组。Reflect是ES6为操作对象而提供的新API。提供了很多新的api用于替代旧的一些不友好的写法。
& `! }* h6 ~, HReflect.ownKeys(obj); // ["name", "age", "job", "hobby"]
|