一、背景
在开发中会遇到时间数组的数据,但是返回的时间数组不是排好顺序的,是错乱的;或者有多组数据,需要组装到一块,但是存在顺序错乱的问题,不知道如何插入,像这种问题,可以使用循环遍历然后比较大小的方式去实现合并排序的功能。
二、思路
1、将时间转换成时间戳
2、格式化数据,转换数据格式,将对象的形式转换成数组对象的方式
3、将需要合并的数据,也格式化成数组对象的方式,并把格式化后的数据放到数组中
4、对数组对象按照timeValue字段的大小进行排序(根据时间戳进行排序)
三、实现方法(核心代码块)
let obj = {};
Object.keys(data).map((code) => {
let codeValueObj = data[code];
let rows = [];
let alarmValueObj = alarmObj[code];
if (codeValueObj) {
Object.keys(codeValueObj).map((time) => {
if (!alarmValueObj[time]) {
let timeValue = new Date(time).getTime();
rows.push({
time: time,
timeValue: timeValue,
value: codeValueObj[time],
});
}
});
}
// 设置报警值
if (alarmValueObj) {
Object.keys(alarmValueObj).map((time) => {
let timeValue = new Date(time).getTime();
rows.push({
time: time,
timeValue: timeValue,
value: alarmValueObj[time],
});
});
}
rows = _.sortBy(rows, function (item) {
return item.timeValue;
});
obj[code] = rows;
});
四、源代码
详细的源代码请到资源中下载,源代码链接