将2D数组拆分为3D数组JavaScript

时间:2017-08-01 07:53:10

标签: javascript arrays

我有一些数据,我想将它拆分两次。数据看起来像这样:

var data = ['a1 b1 c1', 'a2 b2 c2Xa3 b3 c3Xa4 b4 c4', 'a5 b5 c5', 'a6 b6 c6Xa7 b7 c7', 'a8 b8 c8'];

作为第一个分隔符,我使用' X'字符,这很好用:

var firstSplit = new Array(new Array());
    for(var i = 0; i < data.length; i++)
        firstSplit[i] = data[i].split('X');

但是当我使用元素之间的空格作为分隔符时,我得到了#34; Uncaught TypeError:无法设置属性&#39; 0&#39;未定义&#34;,在第二次拆分的行上。

var secondSplit = new Array(new Array(new Array()));
for(var i = 0; i < firstSplit.length; i++) {
    for(var j = 0; j < firstSplit[i].length; j++)
        secondSplit[i][j] = firstSplit[i][j].split(' ');
    }

4 个答案:

答案 0 :(得分:2)

您可以先按X拆分,然后按空格映射拆分值的结果。

var data = ['a1 b1 c1', 'a2 b2 c2Xa3 b3 c3Xa4 b4 c4', 'a5 b5 c5', 'a6 b6 c6Xa7 b7 c7', 'a8 b8 c8'],
    result = data.map(a => a.split('X').map(b => b.split(' ')));
    
console.log(result);
.as-console-wrapper { max-height: 100% !important; top: 0; }

答案 1 :(得分:1)

Array.map是一种更好的方法

&#13;
&#13;
var data = ['a1 b1 c1', 'a2 b2 c2Xa3 b3 c3Xa4 b4 c4', 'a5 b5 c5', 'a6 b6 c6Xa7 b7 c7', 'a8 b8 c8'];

var result = data.map( (str) => {
   return str.split(' ');
});

console.log(result);
&#13;
&#13;
&#13;

答案 2 :(得分:0)

使用var data = ['a1 b1 c1', 'a2 b2 c2Xa3 b3 c3Xa4 b4 c4', 'a5 b5 c5', 'a6 b6 c6Xa7 b7 c7', 'a8 b8 c8']; var firstSplit = new Array(new Array()); for (var i = 0; i < data.length; i++) { firstSplit[i] = data[i].split('X'); } var secondSplit = []; for (var i = 0; i < firstSplit.length; i++) { for (var j = 0; j < firstSplit[i].length; j++) { secondSplit.push(firstSplit[i][j].split(' ')); } } console.log(secondSplit)将每个元素推送到结果数组。

{{1}}

答案 3 :(得分:0)

将空间转换为( - )然后你工作

var str;
var firstSplit = new Array(new Array());
for(var i = 0; i < data.length; i++){
str = data[i].replace(/\s+/g, '-');
    firstSplit[i] = str.split('-');
}