Array.map 想将一个值映射为空
Array.map want to map a value to nothing
我有数组:[1,2,3,4,5,6,7]
我想达到:[[1,2], [3,4], [5,6], [7]]
我在考虑Array.map,但它似乎无法为元素映射到空?
我有(使用 Underscorejs):
arr.map(function(el, idx, arr) {
if (idx%2 != 0) return null;
if (idx == arr.length-1) return [el];
return [el, arr[idx+1]]
}).compact();
这还是有点难看。我怎样才能实现转换(没有显式循环)?
map
function不能那样做,它是一种结构保留转换。
你可以把这个 "chunking" 写成一个 reduce
,一个简单的循环,或者像
这样奇怪的东西
var arr = [1,2,3,4,5,6,7];
return arr.filter(function(_, i) {
return i%2==0;
}).map(function(x, i) {
return i*2+1<arr.length ? [x, arr[i*2+1]] : [x];
});
或
return arr.map(function(_, i) {
return arr.slice(i, 2);
}).filter(function(_, i) {
return i%2==0;
})
另请参阅 Split array into chunks 了解更多变体(其中一些非常实用)。
尝试结合使用地图和过滤器
var output = [1,2,3,4,5,6,7].map(function(value,index,arr){
if(index%2==0)
{
//return [value, arr[index+1]];
return index + 1 < arr.length ? [value, arr[index+1] ] : [ value ];
}
else
{
return false;
}
}).filter(function(value){return value});
console.log(output);
reduce
使用模运算符的数组:
function chunk(arr, n) {
return arr.reduce(function (p, c, i) {
if (i % n === 0) p.push([]);
p[p.length - 1].push(c);
return p;
}, []);
}
chunk(arr, 2); // [[1,2],[3,4],[5,6],[7]]
你就不能做这样的事情吗?
根据 Andy 的建议编辑以防止原始内容被更改
var temp = original.slice();
var newList = [];
while(temp.length)
{
newList.push(temp.splice(0,2));
}
一个循环中的另一个有线解决方案。
var array = [1, 2, 3, 4, 5, 6, 7],
result = array.reduce(function (r, a, i) {
i & 1 && r[i >> 1].push(a) || r.push([a]);
return r;
}, []);
document.write('<pre>' + JSON.stringify(result, 0, 4) + '</pre>');
或功能性(它利用了 )
function due(array) {
return array.length && [array.splice(0, 2)].concat(due(array)) || [];
}
var array = [1, 2, 3, 4, 5, 6, 7],
result = due(array.slice());
document.write('<pre>' + JSON.stringify(result, 0, 4) + '</pre>');
您可以尝试 array.slice()
和 while 循环。
同样使用像map
这样的函数,filter
会迭代每个元素。
function splitArrayInLength(arr, len) {
var returnArr = [];
var index = 0;
while(index < arr.length){
returnArr.push(arr.slice(index, index + len));
index += len;
}
return returnArr;
}
function main() {
var arr = [1, 2, 3, 4, 5, 6, 7];
print(splitArrayInLength(arr, 2));
print(splitArrayInLength(arr, 4));
}
function print(obj){
document.write("<pre>" + JSON.stringify(obj, 0, 4) + "</pre><br/>");
}
main();
我有数组:[1,2,3,4,5,6,7]
我想达到:[[1,2], [3,4], [5,6], [7]]
我在考虑Array.map,但它似乎无法为元素映射到空?
我有(使用 Underscorejs):
arr.map(function(el, idx, arr) {
if (idx%2 != 0) return null;
if (idx == arr.length-1) return [el];
return [el, arr[idx+1]]
}).compact();
这还是有点难看。我怎样才能实现转换(没有显式循环)?
map
function不能那样做,它是一种结构保留转换。
你可以把这个 "chunking" 写成一个 reduce
,一个简单的循环,或者像
var arr = [1,2,3,4,5,6,7];
return arr.filter(function(_, i) {
return i%2==0;
}).map(function(x, i) {
return i*2+1<arr.length ? [x, arr[i*2+1]] : [x];
});
或
return arr.map(function(_, i) {
return arr.slice(i, 2);
}).filter(function(_, i) {
return i%2==0;
})
另请参阅 Split array into chunks 了解更多变体(其中一些非常实用)。
尝试结合使用地图和过滤器
var output = [1,2,3,4,5,6,7].map(function(value,index,arr){
if(index%2==0)
{
//return [value, arr[index+1]];
return index + 1 < arr.length ? [value, arr[index+1] ] : [ value ];
}
else
{
return false;
}
}).filter(function(value){return value});
console.log(output);
reduce
使用模运算符的数组:
function chunk(arr, n) {
return arr.reduce(function (p, c, i) {
if (i % n === 0) p.push([]);
p[p.length - 1].push(c);
return p;
}, []);
}
chunk(arr, 2); // [[1,2],[3,4],[5,6],[7]]
你就不能做这样的事情吗?
根据 Andy 的建议编辑以防止原始内容被更改
var temp = original.slice();
var newList = [];
while(temp.length)
{
newList.push(temp.splice(0,2));
}
一个循环中的另一个有线解决方案。
var array = [1, 2, 3, 4, 5, 6, 7],
result = array.reduce(function (r, a, i) {
i & 1 && r[i >> 1].push(a) || r.push([a]);
return r;
}, []);
document.write('<pre>' + JSON.stringify(result, 0, 4) + '</pre>');
或功能性(它利用了
function due(array) {
return array.length && [array.splice(0, 2)].concat(due(array)) || [];
}
var array = [1, 2, 3, 4, 5, 6, 7],
result = due(array.slice());
document.write('<pre>' + JSON.stringify(result, 0, 4) + '</pre>');
您可以尝试 array.slice()
和 while 循环。
同样使用像map
这样的函数,filter
会迭代每个元素。
function splitArrayInLength(arr, len) {
var returnArr = [];
var index = 0;
while(index < arr.length){
returnArr.push(arr.slice(index, index + len));
index += len;
}
return returnArr;
}
function main() {
var arr = [1, 2, 3, 4, 5, 6, 7];
print(splitArrayInLength(arr, 2));
print(splitArrayInLength(arr, 4));
}
function print(obj){
document.write("<pre>" + JSON.stringify(obj, 0, 4) + "</pre><br/>");
}
main();