Lodash returns 如果数组中只有一个对象,则归约结果错误
Lodash returns wrong reduce result if there is only one object in the array
我得到了一个对象数组,其中包含一些我需要求和的值。有时数组中只有一项。
在那种情况下,我得到了错误的值。
var sumGood = _.reduce([{value:1},{value:2}], function(sum, n) {
return sum.value + n.value; });
console.log(sumGood)
// 3
var sumBad = _.reduce([{value:1}], function(sum, n) {
return sum.value + n.value; });
console.log(sumBad)
// Object {value: 1}
这是fiddle
如何使 return 分别为 3 和 1 的正确结果?
设置初始累加器_.reduce(collection, [iteratee=_.identity], [accumulator], [thisArg])
var sum3 = _.reduce([{
value: 1
}, {
value: 2
}, {
value: 3
}],
function(memo, num) {
return memo + num.value;
},
0
);
console.log(sum3);
var sum1 = _.reduce([{
value: 1
}],
function(memo, num) {
return memo + num.value;
},
0
);
console.log(sum1);
var otherWay = _.reduce([{
value: 1
}, {
value: 2
}, {
value: 3
}], function(memo, num) {
memo.value = memo.value + num.value;
return memo;
}, {
value: 0
}).value;
console.log(otherWay)
<script src="https://cdnjs.cloudflare.com/ajax/libs/underscore.js/1.7.0/underscore-min.js"></script>
首选方案:可以将reduce的第三个参数设置为初始迭代,此处为{value: 0}。没有它,如果你只有一个项目,lodash 就无法知道前面的 sum
是什么。
_.reduce(array, function(sum, n) {
return sum.value + n.value;
}, {value:0});
或者,您可以在 reduce 之前向数组添加 0 值:
array.unshift( {value: 0} ) // now array is [{value:0}, {value:1}}]
或者做一个map-reduce:
_(array).pluck('value').reduce(function(sum, n) { return sum + n; })
或者为什么不先检查数组的大小?
if (array.length === 1) { return array[0].value; } else { ...reduce... }
我得到了一个对象数组,其中包含一些我需要求和的值。有时数组中只有一项。 在那种情况下,我得到了错误的值。
var sumGood = _.reduce([{value:1},{value:2}], function(sum, n) {
return sum.value + n.value; });
console.log(sumGood)
// 3
var sumBad = _.reduce([{value:1}], function(sum, n) {
return sum.value + n.value; });
console.log(sumBad)
// Object {value: 1}
这是fiddle
如何使 return 分别为 3 和 1 的正确结果?
设置初始累加器_.reduce(collection, [iteratee=_.identity], [accumulator], [thisArg])
var sum3 = _.reduce([{
value: 1
}, {
value: 2
}, {
value: 3
}],
function(memo, num) {
return memo + num.value;
},
0
);
console.log(sum3);
var sum1 = _.reduce([{
value: 1
}],
function(memo, num) {
return memo + num.value;
},
0
);
console.log(sum1);
var otherWay = _.reduce([{
value: 1
}, {
value: 2
}, {
value: 3
}], function(memo, num) {
memo.value = memo.value + num.value;
return memo;
}, {
value: 0
}).value;
console.log(otherWay)
<script src="https://cdnjs.cloudflare.com/ajax/libs/underscore.js/1.7.0/underscore-min.js"></script>
首选方案:可以将reduce的第三个参数设置为初始迭代,此处为{value: 0}。没有它,如果你只有一个项目,lodash 就无法知道前面的 sum
是什么。
_.reduce(array, function(sum, n) {
return sum.value + n.value;
}, {value:0});
或者,您可以在 reduce 之前向数组添加 0 值:
array.unshift( {value: 0} ) // now array is [{value:0}, {value:1}}]
或者做一个map-reduce:
_(array).pluck('value').reduce(function(sum, n) { return sum + n; })
或者为什么不先检查数组的大小?
if (array.length === 1) { return array[0].value; } else { ...reduce... }