0

我正在尝试调用天气 API 来获取机器人的当前天气。我正在使用node-rest-client来提取天气描述,该描述将保存在context.forecast. 唯一的问题是,我似乎无法在函数内部修改/创建变量或在函数外部访问它。这是我的代码:

'fetch-forecast': (sessionId, context, cb) => {
    var url = "http://api.openweathermap.org/data/2.5/weather?q="+context.location+"&APPID=APIKEY";
    var forecast;
    Client.get(url, (data, response) => {
      context.forecast = data.weather[0].description;
    });
    cb(context);
  }

context.forecast返回未定义。这样的事情似乎也不起作用:

  'fetch-forecast': (sessionId, context, cb) => {
    var url = "http://api.openweathermap.org/data/2.5/weather?q="+context.location+"&APPID=APIKEY";
    var forecast;
    Client.get(url, (data, response) => {
      forecast = data.weather[0].description;
    });
    context.forecast = forecast;
    cb(context);
  }

context.forecast也在这里返回未定义。关于我做错了什么的任何想法?

[编辑] 尝试过这样的事情,但我仍然无法编辑context.forecast变量:

  'fetch-forecast': (sessionId, context, cb) => {
    var location = context.location;
    var url = "http://api.openweathermap.org/data/2.5/weather?q="+location+"&APPID=APIKEY";
    var forecast;
    function getWeather(url) {
      return new Promise(function(resolve, reject) {
        Client.get(url, (data, response) => {
          resolve(data.weather[0].description);
        });
      });
    }

    getWeather(url).then(function(result) {
      context.forecast = result;
      console.log(context.forecast)
    }).catch(function() {
      context.forecast = "not found";
    });
    console.log(context.forecast);
    cb(context);
  }

第二个console.log返回undefined第一个,第一个console.log返回实际值第二个。我仍然不知道为什么会这样。

4

0 回答 0