js 补全没返回的日期数据

原理:一维数组和二维数组做比较合并去重

1、数据

function mockData() {
    const currentDate = moment(new Date()).date(), // 当天是几号
        currentMDays = moment(new Date()).daysInMonth(), //当前月天数
        year = moment(new Date()).get('year'), //当前年
        month = moment(new Date()).get('month') + 1; //当前年月
    let newData = []

    for(let i = currentDate; i <= currentMDays; i++) {
        newData.push({date: `${year}-${month}-${i}`})
    }
    return newData
}
const apiData = [
    [{date: '2022-10-25', number: 100}, {date: '2022-10-25', number: 200}],
    [{date: '2022-10-28', number: 10}, {date: '2022-10-25', number: 20}]
]

2、去重合并方法

function findAndReplace2(sourceArr, targetArr){
    const arr2 = [];
    sourceArr.forEach((sourceObj) => {
        if (sourceObj.date === targetArr[0].date) {
            arr2.push(...targetArr)
        } else {
            arr2.push(sourceObj)
        }
    })
        return arr2
}

function mergeData(sourceArr, targetArr){
    let result = []
    targetArr.forEach(arr => {
        result = findAndReplace2(result.length === 0 ? sourceArr: result, arr)
    })
    let arr = []
    let tmp = []
    for (let i = 0,j = 1; i <= result.length - 2 ; i++, j++) {
        if ((result[i].date) === result[j].date) {
            tmp.push(result[i])
        } else {
            tmp.push(result[i])
            arr.push(tmp)
            tmp = []
        }
        if (j == result.length - 1) {
            tmp.push(result[j])
            arr.push(tmp)
         }
    }
    return arr;
}

3、合并去重

const newList = mergeData(mockData(), apiData)

mockData() // [{date: '2022-10-21'}, {date: '2022-10-...'}, {date: '2022-10-31'}}

newList 最终为 [
    [{date: '2022-10-21'}],
    [{date: '2022-10-22'}],
    [{date: '2022-10-23'}],
    [{date: '2022-10-24'}],
    [{date: '2022-10-25', number: 100}, {date: '2022-10-25', number: 200}],
    [{date: '2022-10-26'}],
    [{date: '2022-10-27'}],
    [{date: '2022-10-28', number: 10}, {date: '2022-10-28', number: 20}],
    [{date: '2022-10-29'}],
    [{date: '2022-10-20'}],
    [{date: '2022-10-31'}],
]

你可以使用以下方法来获取异步返回数据: 1. 使用回调函数:在发起异步请求后,将一个回调函数作为参数传递给异步函数,当数据返回时,调用该回调函数并将数据作为参数传递给它。 ```javascript function fetchData(callback) { // 异步请求数据 // 假设请求成功后返回数据为data const data = { ... }; // 调用回调函数并传递数据 callback(data); } fetchData(function(data) { // 在回调函数中处理返回数据 console.log(data); }); ``` 2. 使用Promise对象:异步函数返回一个Promise对象,你可以通过调用Promise对象的`then`方法来处理返回数据。 ```javascript function fetchData() { return new Promise(function(resolve, reject) { // 异步请求数据 // 假设请求成功后返回数据为data const data = { ... }; // 将数据传递给resolve函数 resolve(data); }); } fetchData().then(function(data) { // 在then方法中处理返回数据 console.log(data); }); ``` 3. 使用async/await:使用`async`关键字定义一个异步函数,并在需要获取数据的地方使用`await`关键字等待异步操作完成。 ```javascript async function fetchData() { return new Promise(function(resolve, reject) { // 异步请求数据 // 假设请求成功后返回数据为data const data = { ... }; // 将数据传递给resolve函数 resolve(data); }); } async function getData() { const data = await fetchData(); // 在此处处理返回数据 console.log(data); } getData(); ``` 这些方法都可以帮助你在JavaScript中获取异步返回数据,你可以根据具体的需求选择其中一种方法来使用。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值