首页 > 解决方案 > 如何在节点中使用导出的 api 端点并表达

问题描述

我试图更好地理解 express 以及它如何使用不同的端点。

我看到了一个端点示例,它读取了一个像这样使用的 json 文件。

const fs = require('fs');
const path = require('path');

export default app => {
  app.get('/api/price', (req, res) => {
    fs.readFile(path.resolve(__dirname, './price.json'), (err, resp) => {
      if (err) {
        res.send(400, 'ERROR');
      }

      res.send(resp);
    });
  });
};

然后将其导入到 server.js 文件中,如下所示。如您所见,它是作为价格 api 导入的。

import express from 'express';
import priceApi from './priceapi';
const app = express();

priceApi(app)

app.listen(3000, () => {
  console.log("Listening on PORT 3000");
});

我的问题是如何使用这个 priceApi,特别是 `priceApi(app) 并访问存储在 JSON 文件中的信息并从它在 server.js 中引用的端点的 JSON 文件输出信息?

标签: javascriptnode.jsexpress

解决方案


为了不必在每个请求上加载文件,请在应用程序启动期间加载一次 json 文件。然后公开一个新端点并提供 json:

import express from 'express';
import priceApi from './priceapi';
const app = express();
const prices = require('./path/to/prices.json');

app.get('/api/price', (req,res) => {
  res.json(prices); // does not necessarily need to be this, you can also map/filter stuff of the prices-json and only return this data
});

app.listen(3000, () => {
  console.log("Listening on PORT 3000");
});

推荐阅读