Как просто сгладить массив в jQuery? У меня есть:
[1, 2, [3, 4], [5, 6], 7]
И я хочу:
[1, 2, 3, 4, 5, 6, 7]
Как просто сгладить массив в jQuery? У меня есть:
[1, 2, [3, 4], [5, 6], 7]
И я хочу:
[1, 2, 3, 4, 5, 6, 7]
Вы можете использовать jQuery.map, это путь, если вы уже загрузили библиотеку jQuery.
$.map( [1, 2, [3, 4], [5, 6], 7], function(n){
return n;
});
Возвращает
[1, 2, 3, 4, 5, 6, 7]
Используйте силу JavaScript:
var a = [[1, 2], 3, [4, 5]];
console.log( Array.prototype.concat.apply([], a) );
//will output [1, 2, 3, 4, 5]
Здесь вы можете использовать jquery для сглаживания глубоко вложенных массивов:
$.map([1, 2, [3, 4], [5, [6, [7, 8]]]], function recurs(n) {
return ($.isArray(n) ? $.map(n, recurs): n);
});
Возврат:
[1, 2, 3, 4, 5, 6, 7, 8]
Использует jQuery.map, а также jQuery.isArray.
var a = [1, 2, [3, 4], [5, [6, [7, 8]]]];
var b = [];
function flatten(e,b){
if(typeof e.length != "undefined")
{
for (var i=0;i<e.length;i++)
{
flatten(e[i],b);
}
}
else
{
b.push(e);
}
}
flatten(a,b);
console.log(b);
Функция flatten должна делать это, и это не требует jQuery. Просто скопируйте все это в Firebug и запустите его.
Чтобы рекурсивно сгладить массив, вы можете использовать встроенную функцию Array.reduce. Для этого не нужно использовать jQuery.
function flatten(arr) {
return arr.reduce(function flatten(res, a) {
Array.isArray(a) ? a.reduce(flatten, res) : res.push(a);
return res;
}, []);
}
Выполнение
flatten([1, 2, [3, 4, [5, 6]]])
возвращает
[ 1, 2, 3, 4, 5, 6 ]
Вы можете использовать jQuery.map()
:
callback (value, indexOrKey) Функция обработки каждого элемента против. Первым аргументом функции является значение; второй Аргумент - это индекс или ключ свойства массива или объекта. функция может возвращать любое значение для добавления в массив. Возвращенный массив будет сплющен в результирующий массив. Внутри функции это относится к глобальному (оконному) объекту.
Используйте рекурсию, если у вас несколько уровней:
flaten = function(flatened, arr) {
for(var i=0;i<arr.length;i++) {
if (typeof arr[i]!="object") {
flatened.push(arr[i]);
}
else {
flaten(flatened,arr[i]);
}
}
return;
}
a=[1,[4,2],[2,7,[6,4]],3];
b=[];
flaten(b,a);
console.log(b);
Вы можете использовать Array.prototype.reduce
, который технически не jQuery, но действительный ES5:
var multidimensionArray = [1, 2, [3, 4], [5, 6], 7];
var initialValue = [];
var flattened = multidimensionArray.reduce(function(accumulator, current) {
return accumulator.concat(current);
}, initialValue);
console.log(flattened);
Старый вопрос, я знаю, но...
Я нашел, что это работает, и быстро:
function flatten (arr) {
b = Array.prototype.concat.apply([], arr);
if (b.length != arr.length) {
b = flatten(b);
};
return b;
}
Вам нужен arr.flat([depth])
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]