遍历对象是我们实际开发中经常用到的操作,今天就来做一个盘点。
5 p9 w) I! A% F9 f* Dlet obj = {name:"zhang",age:24,job:"程序员",hobby:["音乐","摄影","旅行"]}; 1、for...in遍历; S" ~- L4 W2 m+ T1 V( o: V
for(let item in obj){
console.log(item); //item是对象属性名 name,age,job,hobby
} 2、Object.keys() a4 D) b; b$ P" F
返回对象属性名组成的数组,然后就可以使用数组的遍历方法进行遍历。# G/ l5 o; i [" t! S/ z
Object.keys(obj); // ["name", "age", "job", "hobby"] 3、Object.getOwnPropertyNames()+ ~, `# u- n6 X/ b7 V2 X8 K; H
返回对象属性名组成的数组
4 C, e0 d& ~* v( v+ MObject.getOwnPropertyNames(obj); // ["name", "age", "job", "hobby"] 4、Reflect.ownKeys()
, x& \4 z) i+ ~9 S/ D3 t& O 返回对象属性名组成的数组。Reflect是ES6为操作对象而提供的新API。提供了很多新的api用于替代旧的一些不友好的写法。
4 S K9 R, r; M8 r K; RReflect.ownKeys(obj); // ["name", "age", "job", "hobby"]
|