如何在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]
$.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]
apply([], a)
这段代码的含义吗? :) - Sebastian Patten这里是使用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]
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中并运行。
obj instanceof Array
是非常可靠的。(除非有另一个名为 Array 的变量,那么你可以使用 obj instanceof [].constructor
) - user216441$.isArray
。纯JS很棒,但库也很好用 =]。 - Xavi要递归地展开一个数组,您可以使用原生的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 )是用来处理每个项目的函数。该函数的第一个参数是值;第二个参数是数组或对象属性的索引或键。该函数可以返回任何值以添加到数组中。返回的数组将被展平为结果数组。在函数内部,this指向全局(window)对象。
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;
}
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]
Array.prototype.map
不同,jQuery 的map
对从回调函数返回的数组有特殊处理:_【回调】函数可以返回任何值。返回的数组将被展平到结果数组中_。 - Nickolay