Object.entries和Object.values

博客介绍了具有键值对的数据结构的编译情况,会将键值对编译成二维数组,数组则以下标为键返回。还提及可利用Object.values()进行对象属性遍历,其只返回属性值,数组顺序与相关操作保持一致。

如果一个对象是具有键值对的数据结构,则每一个键值对都会编译成一个具有两个元素的数组,这些数组最终会放到一个数组中,返回一个二维数组。若目标对象是数组,则数组的下标作为键返回。

Object.entries({'id': 1,'name': 'neal_caffreal'}) // [['id',1],['name','neal_caffreal']]
Object.entries([1,2]) // [['0',1],['1',2]]]

 

Object.entries({ [Symbol()]: 1, two: 2 })       //[['two', 2]]

 

使用Object.entries(),我们还可以进行对象属性的遍历。例如:

let obj = { one: 1, two: 2 };
for (let [k,v] of Object.entries(obj)) {
  console.log(`${JSON.stringify(k)}: ${JSON.stringify(v)}`);
}

//输出结果如下:
'one': 1
'two': 2

 

Object.values()

它的工作原理跟Object.entries()很像,顾名思义,它只返回自己的键值对中属性的值。它返回的数组顺序,也跟Object.entries()保持一致。

Object.values({ one: 1, two: 2 })            //[1, 2]
Object.values({ 3: 'a', 4: 'b', 1: 'c' })    //['c', 'a', 'b']

 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值