Vous pouvez utiliser le Array.prototype.reduce
pour faire cela en une seule ligne.
Style ECMAScript 6 :
myArr.reduce((rows, key, index) => (index % 3 == 0 ? rows.push([key])
: rows[rows.length-1].push(key)) && rows, []);
"Normal" JavaScript :
myArr.reduce(function (rows, key, index) {
return (index % 3 == 0 ? rows.push([key])
: rows[rows.length-1].push(key)) && rows;
}, []);
Vous pouvez modifier le chiffre 3 pour qu'il corresponde au nombre de colonnes que vous souhaitez, ou mieux encore, le placer dans une fonction réutilisable :
Style ECMAScript 6 :
const toMatrix = (arr, width) =>
arr.reduce((rows, key, index) => (index % width == 0 ? rows.push([key])
: rows[rows.length-1].push(key)) && rows, []);
"Normal" JavaScript :
function toMatrix(arr, width) {
return arr.reduce(function (rows, key, index) {
return (index % width == 0 ? rows.push([key])
: rows[rows.length-1].push(key)) && rows;
}, []);
}