url = http://api.openweathermap.org/data/2.5/weather;
let x = null;
function getWeather() {
request(`${url}?q=${yourCity}&appid=${apiKey}`, (err, response, body) => {
if(err){
console.log('Upss, something wrong!:', err);
} else {
x = body;
}
});
}
console.log(x);
О, кто-то про асинхронность не читал)
Потому и говорю, что важно. Ты вызываешь консоль.лог синхронно вызову request(), только вот request выполнит переданый ему колбэк (err, response, body) после выполнения console.log
Консоль лог в блоке else
Кстати иф елс тут фигня
Запросы к сети (и ещё некоторые вещи) выполняются асинхронно, это значит, что запрос ты попросил сделать сейчас, а выполнится он потом, и никто не знает ТОЧНО, когда. Может, через секунду, может, через пять минут, в любом случае - потом. Это значит, что весь твой код отработает, включая console.log и любой другой код, а запрос выполнится только после этого. Именно поэтому ты передаешь в request функцию-колбэк, чтобы она была вызвана когда запрос будет выполнен. И работать с результатами тебе нужно в той функции. Или сохранять это куда-то во внешнюю переменную, но запрашивать эти данные из этой переменной тоже только после того, как ты туда их положишь.
Обсуждают сегодня