我如何在。map中跳过数组元素?
我的代码:
var sources = images.map(function (img) {
if(img.src.split('.').pop() === "json"){ // if extension is .json
return null; // skip
}
else{
return img.src;
}
});
这将返回:
["img.png", null, "img.png"]
为什么不直接使用forEach循环?
Let arr = ['a', 'b', 'c', 'd', 'e'];
Let filtered = [];
加勒比海盗。forEach(x => {
If (!x.includes('b')) filter .push(x);
});
console.log(过滤)/ /过滤= = = [' a ', ' c ', ' d ', ' e '];
或者更简单的使用过滤器:
const arr = ['a', 'b', 'c', 'd', 'e'];
const filtered = arr.filter(x => !x.includes('b')); // ['a','c','d','e'];
这里有一个有趣的解决方案:
/**
* Filter-map. Like map, but skips undefined values.
*
* @param callback
*/
function fmap(callback) {
return this.reduce((accum, ...args) => {
const x = callback(...args);
if(x !== undefined) {
accum.push(x);
}
return accum;
}, []);
}
与绑定操作符一起使用:
[1,2,-1,3]::fmap(x => x > 0 ? x * 2 : undefined); // [2,4,6]