Promise.all()。finally()可以返回未解析的数据吗?

时间:2019-03-02 21:41:59

标签: node.js async-await es6-promise

我发现Promise.all()。finally()的行为非常不寻常-看起来像在将map()应用于此函数之前返回了数据。
 1.从数据库接收到的数据。
 2.在map()中调用Google Maps API,应用于从数据库中检索到的数据,并通过Google API调用的结果将其添加到对象属性“ Distance”。
 3.在Promise.all()中返回数据-接收到的数据没有新属性。 我什至无法做到这一点?

public static get = async (req: Request, res: Response) => {
    const latitude = req.query.lat;
    const longitude = req.query.long;
    const pool = await new sql.ConnectionPool(CommonConstants.connectionString).connect();
    const request = pool.request();
    const result = await request.execute('SuppliersSP');
    sql.close();
    const rows = result.recordset.map(async (supplier) => {
        const data = { origin: [latitude, longitude], destination: [supplier.Latitude, supplier.Longitude] };
        const distance = await GetDistance(data) || 0;
        Object.defineProperty(supplier, 'Distance', {
            enumerable: true,
            configurable: true,
            writable: true,
            value: distance
          });
        return supplier;
    })
    Promise.all(rows).finally(() => {
        res.setHeader('Access-Control-Allow-Origin', '*');
        res.status(200).json(rows);
    });
}

这是GetDistance函数:

import { Constants } from "./constants";
const https = require('https');

    export function GetDistance(coords) {
        const { origin, destination } = coords;
        return new Promise((resolve, reject) => {
            https.get(`${Constants.GoogleMapsUrl}?origins=${origin[0]},${origin[1]}
             &destinations=${destination[0]},${destination[1]}
             &key=${Constants.GoogleMapsApiKey}`, (resp) => {
                let data = '';
                resp.on('data', (chunk) => {
                    data += chunk;
                });
                resp.on('end', () => {
                    const distance = JSON.parse(data);
                    resolve(distance.rows[0].elements[0].distance.value);
                });
            }).on("error", (err) => {
                reject("Error: " + err.message);
            });
        });
    }

1 个答案:

答案 0 :(得分:0)

通过将.finally()更改为.then()来解决。