Maybe it's stupid question but I cannot realize is that possible to flatten multidimensional array without recursion?
I have one solution written by me with recursion:
function transform (arr) {
var result = [];
arr.forEach(flatten)
function flatten (el) {
if (Array.isArray(el)) {
return el.forEach(flatten);
}
return result.push(el);
}
return result;
}
Example of an array to flatten:
[1, {a: [2, 3]}, 4, [5, [6]], [[7], 8, 9], 10]
And execution:
var a = [1, {a: [2, 3]}, 4, [5, [6]], [[7], 8, 9], 10];
var r = transform(r);
console.log(r); // [1, {a: [2, 3]}, 4, 5, 6, 7, 8, 9, 10]
Thanks!
[].concat.apply([], arr);
won't do the trick for multiple nestings :/ – Tubulevar a = [1, 4, [5, [6]], [[[5],[6],[[7]]], 8, 9], 10];console.log(a.toString().split(','))
– Ellen