如何使用forEach和Mongoose查询计算最终价格?

时间:2018-05-21 01:41:00

标签: javascript node.js mongoose

我对Mongoose Queries有一个困难的最终价格计算问题。我有三个功能。这个得到一个ID和外部数量,找到材料价格,最后多了几个。

async function getPrivatePrice(id, quantity) {
  try {
    let piece = await Piece.findOne({'_id': id}).select({"meterage": 1, "material": 1, "_id" : 0}).then((piece) => {
      return piece;
    }).catch((err) => {
      console.log(err);
    });

    let price = await Material.findOne({'_id': piece.material}).select({"_id" : 0, "price" : 1}).then((price) => {
      return price;
    }).catch((err) => {
      console.log(err);
    });
    let final_raw = piece.meterage * price.price;
    let final_price = final_raw * quantity;
    return { final_price : final_price }

  } catch(err) {
    console.log(err);
  }
}

我在代码的第二部分遇到了困难,因为我需要从另一个函数中获取许多id,因此,我决定使用forEach来调用这个函数,并获取所有这些价格并将它们放入一个数组,但我不知道如何返回它。

async function getFinalCost(pieces) {
  let total_cost = [];
  try {
    pieces.forEach(async (response) => {
      let query = await PieceController.getPrivatePrice(response["_id"], response["quantity"]).then((piecePrice) => {
        return piecePrice["final_price"];
      }).catch((err) => {
        console.log(err);
      });
      total_cost.push(query);
    });
    return total_cost;

  } catch(err) {
    console.log(err);
  }
}

我想知道如何在这里获取该数组:

function createProduct(req, res) {

  let params = req.body;
  let product = new Product();
  product.name = params.name;
  product.reference = params.reference;
  product.pieces = params.pieces;
  product.color = params.color;
  let piece_price = getFinalCost(product.pieces);
  console.log(piece_price); //Outputs Promise { { total_array: [] } }
}

1 个答案:

答案 0 :(得分:0)

您显然需要重构代码。我会做的是使用像bluebird这样的东西在片段列表上运行地图,如此。

const Promise = require('bluebird');

async function getMoreProductInfo(id) {
    try{
        const productInfo = await Piece.findOne({'_id': id}).select({"meterage": 1, "material": 1, "_id" : 0});
        const materialInfo = await Material.findOne({'_id': productInfo.material}).select({"_id" : 0, "price" : 1});
        return { productInfo, materialInfo };
    } catch(e) {
        throw e;
    }
}

async function calculatePrices(pieces) {
    try {
        const priceList = await Promise.map(pieces, async (piece) => {
            const { productInfo, materialInfo } = await getMoreProductInfo(piece._id);
            return materialInfo.price * piece.quantity * productInfo.meterage;
        });
        return priceList
    } catch (e) {
        throw e;
    }
}

我显然无法按原样测试此代码。但我认为说出最新情况应该非常简单(我认为)