Не все элементы после async / await в вызове Array.map () решаются - PullRequest
2 голосов
/ 27 мая 2019

Я разместил вопрос в этом сообщении ранее. Наконец, он показывает некоторый вывод после изменения синхронных функций на асинхронные; однако оказывается, что в выходном массиве некоторые элементы равны нулю. Я не уверен, почему?

основной код выглядит так:

router.post('/form1',  async (req, res, next)=>{

try{
    const emdate = new Date(req.body.emdate);
    const address = req.body.address;
    const stationDataCursor = stationData.filteredData(instantData, emdate);

    stationDataCursor.toArray().then(async (docArr)=>{


            return await Promise.all(docArr.map(async function(val, ind){

                try {
                    const feature = await calcDSV.calcDSV(val);                        
                    return feature

                } catch (error) {

                    console.log(ind);
                    console.log("Error happened in data array", error);

                }

            }));


    }).then((doc)=>{
        res.json(doc)
    })

} catch(error){
    res.status(400).send(error)
}
})

Я пытался добавить Promise.resolve(featureJSON) в ответ calcDSV(val)

async function calcDSV(featuresJSON){

    // featuresJSON  
    const SVscore = [];
    const tuEval = featuresJSON.features.properties.TU90; // array
    const obArr = featuresJSON.features.properties.OB; // array
    const periodObj = await getPeriods(tuEval);// get period position
    const paramObj = await getParams(periodObj, obArr); // get parameters
    const periodDate =  await getPeriodDate(featuresJSON, periodObj);
    const removeTime =  periodDate.beginDate.map(x=>x.split('T')[0]);


    let hourly = paramObj.hourCounts;
    let avgTemps = paramObj.avgTemps;


    for(let i = 0;i<hourly.length; i++){

        let score = await assignScore(avgTemps[i], hourly[i]);
        SVscore.push(score);

    }

    // output sv score for date


    const aggreScore = await accumScore(removeTime, SVscore);


    aggreScore.DSVdate = aggreScore.Date.map(x=>new Date(x));


    featuresJSON.features.properties.periodSV = SVscore;
    featuresJSON.features.properties.Periods = periodDate;
    featuresJSON.features.properties.DSVscore = aggreScore;

    return  Promise.resolve(featuresJSON);
}


module.exports.calcDSV = calcDSV;

Сообщение об ошибке:

2
Error happened in data array ReferenceError: error is not defined
at getParams (/media/swaggyp1985/HDD4T/OSU_Projects_2017-2018/App_Projects/wallin_model/dev/dev_js/wallin-server/src/utils/periodFunc.js:145:9)
at Object.calcDSV (/media/swaggyp1985/HDD4T/OSU_Projects_2017-2018/App_Projects/wallin_model/dev/dev_js/wallin-server/src/utils/wallinLogic.js:842:32)
at processTicksAndRejections (internal/process/task_queues.js:86:5)
6
Error happened in data array ReferenceError: error is not defined
at getParams (/media/swaggyp1985/HDD4T/OSU_Projects_2017-2018/App_Projects/wallin_model/dev/dev_js/wallin-server/src/utils/periodFunc.js:145:9)
at Object.calcDSV (/media/swaggyp1985/HDD4T/OSU_Projects_2017-2018/App_Projects/wallin_model/dev/dev_js/wallin-server/src/utils/wallinLogic.js:842:32)
at processTicksAndRejections (internal/process/task_queues.js:86:5)
...

Я ожидаю, что каждый элемент будет решен.

1 Ответ

1 голос
/ 27 мая 2019

Благодаря комментариям я смог выяснить источник: throw error() в других функциях, которые я определил. Это должно быть throw Error().

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...