为什么未解决“承诺{<pending>}”?

时间:2019-04-07 15:22:55

标签: javascript node.js isomorphic-fetch-api

我正在尝试从Storm Glass API中获取数据。我正在使用他们的模板提取请求(https://docs.stormglass.io/?javascript#point-request)。

当我运行脚本时,控制台将无限期地读出“ Promise { <pending> }”。因此,请求未返回值,但我无法弄清楚原因。有什么想法吗?

我已将我的API密钥替换为<My API key>

const http = require('http')
const fetch = require('isomorphic-fetch');

http.createServer((req, res) => {

////////////////////////////////////////////////App code
const lat = 58.7984;
const lng = 17.8081;
const params = 'waveHeight,airTemperature';

fetch(`https://api.stormglass.io/point?lat=${lat}&lng=${lng}&params=${params}`, {
  headers: {
    'Authorization': '<My API key>'
  }
}).then(function(response) {
  // Do something with response data.
  const jsonData = response.json();
  console.log(jsonData)
});

/////////////////////////////////////////////////////////
}).listen(3000);

console.log("service running on http://localhost:3000");

3 个答案:

答案 0 :(得分:5)

response.json函数返回一个Promise,而不是反序列化的对象。您的代码应为:

fetch(`https://api.stormglass.io/point?lat=${lat}&lng=${lng}&params=${params}`, {
  headers: {
    'Authorization': '<My API key>'
  }
})
.then(response => response.json())
.then(function(jsonData) {
  // Do something with response data
  console.log(jsonData)
});

答案 1 :(得分:1)

除了gretro的答案外,您可能会想到const json = response.json()可以通过查看async/await代码来工作,因为它非常相似,因此,如果以这种方式编写,则代码看起来像这样。传统上,它是用try/catch包装的,所以我也将其包括在内。

http.createServer(async (req, res) => {

  const lat = 58.7984;
  const lng = 17.8081;
  const params = 'waveHeight,airTemperature';

  try {
    const endpoint = `https://api.stormglass.io/point?lat=${lat}&lng=${lng}&params=${params}`;
    const params = { headers: { 'Authorization': '<My API key>' } };
    const response = await fetch(endpoint, params);
    const jsonData = await response.json();
    console.log(jsonData);
  } catch (err) {
    console.error(err);
  }

}).listen(3000);

答案 2 :(得分:0)

您可以使用async / awiat解决承诺。

fetch(`https://api.stormglass.io/point?lat=${lat}&lng=${lng}&params=${params}`, {
  headers: {
    'Authorization': '<My API key>'
  }
})
.then(async response => {
    const jsonData = await response.json();
    console.log(jsonData)
})