Ожидание завершения вызова API в Javascript перед продолжением
То, с чем я боролся в прошлом и с чем борюсь сегодня, - это предотвращение продолжения API / AJAX до тех пор, пока вы не получите свой ответ. в настоящее время я работаю с API Facebook. Мне нужно получить ответ от вызова, а затем вернуть его, но происходит то, что моя функция возвращается до того, как я получу ответ от вызова API. Я знаю, почему это происходит, я просто не могу понять, как это предотвратить! Вот мой код ...
function makeCall(){
var finalresponse = "";
var body = 'Test post';
FB.api('/me/feed', 'post', { message: body }, function(response) {
if (!response || response.error) {
finalresponse = response.error;
} else {
finalresponse = 'Post ID: ' + response.id;
}
});
return finalresponse;
}
// ----- РЕДАКТИРОВАТЬ
Я заметил, что некоторые люди предложили что-то вроде этого ...
function makeCall(){
var finalresponse = "";
FB.api('/me/feed', 'post', { message: body }, function(response) {
if (!response || response.error) {
finalresponse = response.error;
return finalresponse;
} else {
finalresponse = 'Post ID: ' + response.id;
return finalresponse;
}
});
}
Но это возвращает неопределенный
// РЕДАКТИРОВАТЬ НА ОСНОВЕ ОБНОВЛЕНИЙ
function share_share(action_id){
var finalresponse = makeCall(action_id, process);
return finalresponse;
}
function makeCall(action_id, callback){
var body = 'Test post';
FB.api('/me/feed', 'post', { message: body }, function (response) {
if (!response || response.error) {
var finalresponse = response.error;
} else {
finalresponse = 'Post ID: ' + response.id;
}
callback(action_id, finalresponse);
});
}
function process(action_id, finalresponse){
console.log(finalresponse);
}