--- title: Array.prototype.flat() slug: Web/JavaScript/Reference/Global_Objects/Array/flat tags: - Array - JavaScript - Масив - метод translation_of: Web/JavaScript/Reference/Global_Objects/Array/flat ---
Метод flat() створює новий масив який містить всі елементи вкладених масивів до вказаної глибини.
\{{EmbedInteractiveExample("pages/js/array-flatten.html")}}
var newArray = arr.flat([depth]);
depth {{optional_inline}}Новий масив, що містить елементи вкладених масивів.
var arr1 = [1, 2, [3, 4]]; arr1.flat(); // [1, 2, 3, 4] var arr2 = [1, 2, [3, 4, [5, 6]]]; arr2.flat(); // [1, 2, 3, 4, [5, 6]] var arr3 = [1, 2, [3, 4, [5, 6]]]; arr3.flat(2); // [1, 2, 3, 4, 5, 6]
Метод flat видаляє порожні елементи масивів:
var arr4 = [1, 2, , 4, 5]; arr4.flat(); // [1, 2, 4, 5]
reduce і concatvar arr1 = [1, 2, [3, 4]]; arr1.flat(); //вирівняти один рівень масиву arr1.reduce((acc, val) => acc.concat(val), []); // [1, 2, 3, 4] //або const flatSingle = arr => [].concat(...arr);
//щоб здійснити глибоке вирівнювання, використовуйте рекурсію з reduce і concat
var arr1 = [1,2,3,[1,2,3,4, [2,3,4]]];
function flattenDeep(arr1) {
return arr1.reduce((acc, val) => Array.isArray(val) ? acc.concat(flattenDeep(val)) : acc.concat(val), []);
}
flattenDeep(arr1); // [1, 2, 3, 1, 2, 3, 4, 2, 3, 4]
//глибоке вирівнювання без рекурсії, використовуючи stack
var arr1 = [1,2,3,[1,2,3,4, [2,3,4]]];
function flatten(input) {
const stack = [...input];
const res = [];
while (stack.length) {
// викидаємо значення зі стеку
const next = stack.pop();
if (Array.isArray(next)) {
// додаємо елементи масиву, не змінюючи вхідного масиву
stack.push(...next);
} else {
res.push(next);
}
}
//перевертаємо масив, щоб порядок сортування відповідав вхідному
return res.reverse();
}
flatten(arr1); // [1, 2, 3, 1, 2, 3, 4, 2, 3, 4]
//глибоке вирівнювання з рекурсією
function flatten(array) {
var flattend = [];
(function flat(array) {
array.forEach(function(el) {
if (Array.isArray(el)) flat(el);
else flattend.push(el);
});
})(array);
return flattend;
}
Будь ласка, не додавайте поліфіли в цю статтю. За довідкою дивіться: https://discourse.mozilla.org/t/mdn-rfc-001-mdn-wiki-pages-shouldnt-be-a-distributor-of-polyfills/24500
| Специфікація | Статус | Коментар |
|---|---|---|
Array.prototype.flat proposal |
Finished (4) |
{{Compat("javascript.builtins.Array.flat")}}