题目:
var arr = [
{ name: '小米1', value: 1, type: 2, date: '2018-06-07T08:00:01.589Z' },
{ name: '锤子T1', value: 1, type: 2, date: '2018-06-07T08:10:01.589Z' },
{ name: '小米2', value: 1, type: 4, date: '2018-06-07T20:00:01.589Z' },
{ name: '小米2', value: 4, type: 4, date: '2018-06-07T20:10:21.189Z' },
{ name: '小米4', value: 1, type: 4, date: '2018-06-07T08:00:01.560Z' },
{ name: '小米4', value: 2, type: 4, date: '2018-06-07T08:10:31.584Z' },
{ name: '小米6', value: 1, type: 3, date: '2018-06-07T08:00:01.589Z' },
{ name: '小米5s', value: 1, type: 4, date: '2018-06-07T08:00:01.589Z' },
{ name: '锤子T2', value: 1, type: 4, date: '2018-06-07T08:00:01.589Z' },
{ name: '锤子T1', value: 4, type: 4, date: '2018-06-07T08:06:01.589Z' },
{ name: '魅蓝note5', value: 1, type: 4, date: '2018-06-07T08:00:01.589Z' },
{ name: '魅蓝note2', value: 5, type: 4, date: '2018-06-02T08:07:01.589Z' },
{ name: '魅蓝note2', value: 6, type: 4, date: '2018-06-07T08:00:01.589Z' },
{ name: '魅蓝note3', value: 1, type: 4, date: '2018-06-05T08:00:01.589Z' },
{ name: '魅蓝note', value: 1, type: 4, date: '2018-06-07T08:00:01.589Z' },
{ name: 'oppor9', value: 7, type: 4, date: '2018-06-04T08:04:01.588Z' },
{ name: '华为p9', value: 1, type: 4, date: '2018-06-02T08:00:01.577Z' },
{ name: '华为p9', value: 2, type: 4, date: '2018-06-07T08:00:01.110Z' },
{ name: '华为p10', value: 1, type: 1, date: '2018-06-07T08:00:01.534Z' }
];
- 请用您认为最优化的方式,将arr中的type为4的数据过滤出来,
- 然后按相同的 name + date(按天)合并value(value累加),
- 然后按 value 降序(从大到小)排序,
- 最后每行按照
${name},${本地日期},售出${sum(value)}部"
的格式,如:"小米2,2017年06月08日,售出5部", 打印(console.log)出来。 - 可以使用第三方js库,可以使用es6。
- 请在半小时内完成。
要求最后输出结果样例如下:
oppor9,2017年06月04日,售出7部
魅蓝note2,2017年06月07日,售出6部
魅蓝note2,2017年06月02日,售出5部
小米2,2017年06月08日,售出5部
......
方案:
var newArr1 = arr.filter(item => item.type === 4); // 1. 将arr中type为4的数据过滤出来
var newArr2 = mergeArray(newArr1); // 2. 按相同的name + date(按天)合并value(value累加)
var newArr3 = newArr2.sort((a, b) => b.value - a.value); // 3. 按value降序(从大到小)排序
printArrar(newArr3); // 4. 每行按照name,本地日期,售出X部的格式,打印出来
// 按相同的name + date(按天)合并value(value累加)
// 数组的下标可以是字符串
function mergeArray(source) {
var temp = [];
source.forEach(item => {
var key = item.name + item.date.slice(0, 10);
if (typeof temp[key] === 'undefined') {
temp[key] = item;
} else {
temp[key].value += item.value;
}
});
var result = [];
for (var i in temp) {
result.push(temp[i]);
}
return result;
}
// 每行按照name,本地日期,售出X部的格式,打印出来
function printArrar(array) {
array.forEach(item => {
var date = item.date.slice(0, 10).split('-');
console.log(`${item.name},${date[0]}年${date[1]}月${date[2]}日,售出${item.value}部`);
});
}
知识点:数组的下标,可以是字符串