javascript - 根据货币获取记录

标签 javascript node.js express mongoose

我有门票表,每张门票都有一个价格。我已将数据库中的基数设置为美元,假设有人想从美国以外的国家/地区购买机票,我想以本地货币向用户显示价格。什么是合适的方法。首先,我虽然可以在运行时将门票价格转换为本地货币,但由于门票数量可能很大,因此此操作的成本很高。

对于货币转换,我使用 Open Exchange Rates API ,我需要根据通过 req.query 提供的货币提供价格。

我不能在这里显示实际代码,但我有一个示例:

const express = require('express');
const Product = require('../models/Product');
const { fetchRates } = require('../services/fx_rates')

const router = new express.Router();

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

    const product = new Product({
        ...req.body
    });

    try {
        await product.save();
        res.status(201).send(product);
    } catch (e) {
        res.send(400).send(e);
    }
});

router.get('/products', async (req, res) => {
    try {
        const products = await Product.find()
        // if (req.query.to) {
        //     for (let product of products) {
        //         fetchRates(product.price, 'USD', to)
        //             .then(price => {
        //                 product.price = price
        //             })
        //             .catch(e => console.log(e))

        //     }
        // }
        console.log(products)
        res.status(200).send({ products: products })
    } catch (e) {
        res.status(500).send();
    }
});

module.exports = router

最佳答案

一种方法是获取所需本地货币相对于美元的兑换率,然后使用代码而不是 API 来兑换价格。您可以使用 open exchange latest.json endpoint为了它。 这是一个例子。

const rp = require('request-promise');

async function getConversionRate(localCurrency, base = 'USD'){
  const options = {
    uri: 'https://openexchangerates.org/api/latest.json',
    qs: {
      app_id: 'YOUR_APP_ID',
      base: base,
      symbols: localCurrency,
    },
    json: true
  };
  const result = await rp(options);
  /*
  {
    disclaimer: "https://openexchangerates.org/terms/",
    license: "https://openexchangerates.org/license/",
    timestamp: 1449877801,
    base: "USD",
    rates: {
        INR: 71.43
    }
  }
  */
  return result.rates[localCurrency];
}

router.get('/products', async (req, res) => {
    try {
        const [products, conversionRate] = await Promise.all([Product.find(), getConversionRate(req.query.to)])
        const convertedProducts = products.map(p => {
          p.price = p.price * conversionRate;
          return p;
        });
        console.log(convertedProducts)
        res.status(200).send({ products: convertedProducts })
    } catch (e) {
        res.status(500).send();
    }
});

module.exports = router;

关于javascript - 根据货币获取记录,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59521941/

相关文章:

json - 通过express将.json文件中的json对象导出到vue并赋值给变量

javascript - 使用 puppeteer 在具有窗口访问的真实浏览器环境中运行 jest 单元测试

javascript - 无法在 javascript 中为音频设置 currentTime(仅限 IOS)

javascript - 表达和 Sequelize : eager loading belongs to many associations hangs application

javascript - 如何使用 Node 检查器在 "require"-d 库内设置断点?

javascript - 使用 async/await 时 try/catch 中的范围问题

javascript - 在输入选择填充数据字段之前触发模糊验证 - ReactJS

javascript - 使用 JS/jquery 选择多个图像

node.js - 如何在nodejs中等待异步函数完成执行

node.js - 当服务器启动使用keystonejs时,如何触发函数?