首页 > 解决方案 > 将数组格式化为对象 javascript

问题描述

我有两个数组 ( x, y) 有一些数字序列,两个数组都来自相同的长度。现在我需要将两个数组的元素组合成一个对象。要创建对象,我有一个函数f如何快速将其转换为单个对象数组

x = [1,2,3,4] 
y = [5,6,7,8]
f = function(x,y) { return { foo: x, bar: y } }
... some magic ...
result = [{ foo: 1, bar: 5},
          { foo: 2, bar: 6},
          { foo: 3, bar: 7},
          { foo: 4, bar: 8}]

当然这可以使用

const array = []
for (let i = 0; i <= x.length; i++) {
    array.push(f(x[i],y[i]))
}

但我想知道是否有更“清洁”的方式?使用 .map 例如?或者这是要走的路?

-Edit- 谢谢大家,不知道map也可以将索引作为参数传递。

标签: javascript

解决方案


您可以使用变量名称作为键构建一个对象,并迭代对象的所有条目,并将数组的索引作为结果数组对象的索引。

这适用于任意长度的数组。

var foo = [1, 2, 3, 4],
    bar = [5, 6, 7, 8],
    result = Object
        .entries({ foo, bar })
        .reduce((r, [k, a]) => a.map((v, i) => Object.assign(r[i] || {}, { [k]: v })), []);
    
console.log(result);
.as-console-wrapper { max-height: 100% !important; top: 0; }


推荐阅读