7种Javascript对象属性遍历的方法。
测试数据
1 | var name = 'mingliang.gao'; |
方法一:for…in
for…in循环遍历对象自身的和继承的可枚举属性(不含 Symbol 属性)。
1 | for (let k in demo){ |
结果:
1 | name |
方法二:Object.keys(obj)
Object.keys返回一个数组,包括对象自身的(不含继承的)所有可枚举属性(不含 Symbol 属性)的键名。
1 | console.log(Object.keys(demo)) |
结果:
1 | [ 'name', 'language', 'say' ] |
方法三:Object.getOwnPropertyNames(obj)
Object.getOwnPropertyNames返回一个数组,包含对象自身的所有属性(不含 Symbol 属性,但是包括不可枚举属性)的键名。
1 | console.log(Object.getOwnPropertyNames(demo)) |
结果:
1 | [ 'name', 'language', 'say' ] |
方法四:Object.getOwnPropertySymbols(obj)
Object.getOwnPropertySymbols返回一个数组,包含对象自身的所有 Symbol 属性的键名。
1 | console.log(Object.getOwnPropertySymbols(demo)) |
结果:
1 | [ 'name', 'language', 'say' ] |
方法五:Reflect.ownKeys(obj)
Reflect.ownKeys返回一个数组,包含对象自身的(不含继承的)所有键名,不管键名是 Symbol 或字符串,也不管是否可枚举。
1 | console.log(Reflect.ownKeys(demo)) |
结果:
1 | [ 'name', 'language', 'say' ] |
方法六:getOwnPropertyDescriptor(obj, ‘属性名’)
对象的每个属性都有一个描述对象(Descriptor),Object.getOwnPropertyDescriptor方法可以获取该属性的描述对象。
1 | console.log(getOwnPropertyDescriptor(demo, 'name')) |
结果:
1 | { value: 'mingliang.gao', |
方法七:解构赋值
1 | let { name, language, say, ...args } = demo; |
结果:
1 | mingliang.gao |