我有一个对象数组,我想对其进行迭代以生成一个新的过滤数组。同时,我还需要根据参数从新数组中过滤出一些对象。我试着这样做:
function renderOptions(options) {
return options.map(function (option) {
if (!option.assigned) {
return (someNewObject);
}
});
}
这是个好方法吗?有没有更好的方法?我愿意使用任何库,如lodash。
在某些情况下,使用forEach不是更容易(或同样容易)吗
Var选项= [
{name: 'One', assigned: true},
{name: 'Two',赋值:false},
{name: 'Three',赋值:true},
];
Var减小= []
options.forEach(功能(选项){
If (option.assigned) {
var someenewvalue = {name: option.name, newProperty: 'Foo'}
reduced.push (someNewValue);
}
});
. getelementbyid(“输出”)。innerHTML = JSON.stringify(简化);
<h1>仅分配选项</h1>
<pre id="output"> </pre> .
但是,如果有一个malter()或fap()函数组合映射和过滤器函数就更好了。它将像过滤器一样工作,除了返回true或false之外,它将返回任何对象或null/undefined。
直接使用.reduce可能很难阅读,所以我建议创建一个生成reducer的函数:
function mapfilter(mapper) {
return (acc, val) => {
const mapped = mapper(val);
if (mapped !== false)
acc.push(mapped);
return acc;
};
}
像这样使用它:
const words = "Map and filter an array #javascript #arrays";
const tags = words.split(' ')
.reduce(mapfilter(word => word.startsWith('#') && word.slice(1)), []);
console.log(tags); // ['javascript', 'arrays'];
我用以下几点优化了答案:
重写if (cond) {stmt;}作为cond && stmt;
使用ES6箭头函数
我将给出两个解决方案,一个使用forEach,另一个使用reduce:
解决方案1:使用forEach
该解决方案通过使用forEach遍历每个元素来实现。然后,在forEach循环的主体中,我们有条件作为过滤器,它决定我们是否要向结果数组追加一些内容。
Const选项= [
{name: 'One', assigned: true},
{name: 'Two',赋值:false},
{name: 'Three',赋值:true},
];
Const reduced = [];
选项。forEach(o => {
O.assigned && reduced。push({name: o.name, newProperty: 'Foo'});
});
console.log(减少);
解决方案2:使用reduce
这个解决方案使用array. prototype.reduce而不是forEach来迭代数组。它认识到这样一个事实,即reduce具有内置的初始化式和循环机制。除此之外,该解决方案与forEach解决方案或多或少是相同的,因此,区别在于修饰语法。
Const选项= [
{name: 'One', assigned: true},
{name: 'Two',赋值:false},
{name: 'Three',赋值:true},
];
Const reduced = options。Reduce ((a, o) => {
o.assigned && a.push({name: o.name, newProperty: 'Foo'});
返回一个;
}, []);
console.log(减少);
我让你来决定采用哪种解决方案。