在数组中的同一索引处推送多个元素



如何在 JavaScript 中将多个元素推送到数组的一个索引?

就像我一样

arr1["2018-05-20","2018-05-21"];
arr2[5,4];

我希望结果第 4 个数组如下所示:

arr4[["2018-05-20",5],["2018-05-21",4]];

尝试像这样推动:

arr1.push("2018-05-20","2018-05-21");
arr1.push(5,4);

最后是:

arr4.push(arr1);

但结果并不像预期的那样。请有人帮忙。

实际上我想在zingChart中使用它作为:

选项数据 创建一个选项对象,并添加一个数组的值数组。

日历值在每个数组中,按以下格式为日历日期提供相应的数字值。

options: {
values: [
['YYYY-MM-DD', val1],
['YYYY-MM-DD', val2],
...,
['YYYY-MM-DD', valN]
]
}

你的问题根本不正确,因为你不能在一个数组的同一索引上推送多个元素。结果是一个多维数组:

[["2018-05-20",5],["2018-05-21",4]]
  • 你必须创建一个收集所有数据的多维数组(arrAll(
  • 然后创建另一个多维数组 (arrNew( 重新排列以前的数据

请尝试以下操作:

// Your Arrays
var arr1 = ["2018-05-20","2018-05-21"];
var arr2 = [5, 4];
//var arr3 = [100, 20];
var arrAll = [arr1, arr2]; 
//var arrAll = [arr1, arr2, arr3]; 

// New Array definition
var arrNew = new Array;
for (var j = 0; j < arr1.length; j++) {
var arrTemp = new Array
for (var i = 0; i < arrAll.length; i++) {
arrTemp[i] = arrAll[i][j];
if (i === arrAll.length - 1) {
arrNew.push(arrTemp)
}
}
}

//New Array
Logger.log(arrNew)

假设你想要一个多维数组,你可以将所有输入变量放入一个数组中。使用reduceforEach根据索引对数组进行分组。

let arr1 = ["2018-05-20","2018-05-21"];
let arr2 = [5,4];
let arr4 = [arr1, arr2].reduce((c, v) => {
v.forEach((o, i) => {
c[i] = c[i] || [];
c[i].push(o);
});
return c;
}, []);
console.log(arr4);

相关内容

  • 没有找到相关文章

最新更新