如何获得Express Node路由以在渲染之前等待功能

问题描述 投票:0回答:1

我正在尝试获取一条路径,以等待另一个模块中的异步功能在渲染运行之前返回,但是无论我做什么,res.render总是先运行。这是我当前的代码,实际上只是冻结而从不加载:

router.get('/', function(req, res, next) {
  try {
    const cities = spreadsheet.getData()

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

  res.render('index', { cities: cities})
})

并且它正在等待的功能是这样:

exports.getData = function () {
  parsedData = [];
  accessSpreadsheet().then(function(data) {
    console.log(parsedData)
    return parsedData;
  });
};

const accessSpreadsheet = async() => {
  await doc.useServiceAccountAuth({
      client_email: process.env.GOOGLE_SERVICE_ACCOUNT_EMAIL,
      private_key: process.env.GOOGLE_PRIVATE_KEY,
    });
  const loadedDoc =  await doc.loadInfo();
  sheet = await doc.sheetsByIndex[0];
  const cells = await sheet.loadCells(allCells[cellsIndex]);
  const data = await parseData();
  const moreCells = await checkNextCells()

  return;
}

首先运行渲染,然后在控制台中打印parsedData。我还尝试使路由异步,并在回调中尝试了res.render。有什么办法可以使这项工作吗?

node.js express async-await render router
1个回答
0
投票

由于accessSpreadSheetasync函数,因此您需要await或在getData函数中以及在路由器中类似地返回诺言(由Patrick Roberts在注释中建议)。

使用异步等待,您可以按以下方式更新代码(未测试)

exports.getData = function () {
  parsedData = [];
  parsedData = await accessSpreadSheet();
  return parsedData;
};

const accessSpreadsheet = async() => {
  await doc.useServiceAccountAuth({
      client_email: process.env.GOOGLE_SERVICE_ACCOUNT_EMAIL,
      private_key: process.env.GOOGLE_PRIVATE_KEY,
    });
  const loadedDoc =  await doc.loadInfo();
  sheet = await doc.sheetsByIndex[0];
  const cells = await sheet.loadCells(allCells[cellsIndex]);
  const data = await parseData();
  const moreCells = await checkNextCells()

  return;
}

在路由器中

router.get('/', async function(req, res, next) {
  try {
    const cities = await spreadsheet.getData()

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

  res.render('index', { cities: cities})
})
© www.soinside.com 2019 - 2024. All rights reserved.