Как использовать YAHOO.util.Connect.asyncRequest и вернуть результаты?
Я использую YAHOO.util.Connect.asyncRequest для получения данных из базы данных, вот код:
function getCountArticle(contentCurValue) {
var handleSuccess = function (res) {
var countPubmed = YAHOO.lang.JSON.parse(res.responseText);
var contentCountPubmed = countPubmed.totalArticleRecords;
alert(contentCountPubmed); //return 15 for example
};
var handleFailure = function () {
alert("Error connecting data : Bad pubmed query");
};
var callback =
{
success:handleSuccess,
failure:handleFailure,
timeout: 5000
};
var sURL = 'qct-list-article.html?term=' + contentCurValue + '&retstart=0' + '&retmax=1';
var request = YAHOO.util.Connect.asyncRequest('GET',sURL,callback);
}
Я хотел бы, чтобы эта функция возвращала: "contentCurValue" (например:15), но когда я пытаюсь использовать этот код, я получаю "undefined":
var test = getCountArticle();
alert(test); // return undefined, should return 15
Моя ошибка, вероятно, из-за асинхронного запроса, но как я могу заставить "var test = getCountArticle();" ждать результатов?
1 ответ
Поскольку вызов по своей природе является асинхронным, а не пытаться ждать ответа, было бы лучше указать функцию обратного вызова для выполнения с данными. Вы можете изменить свой метод следующим образом:
function getCountArticle(contentCurValue, callback) {
var handleSuccess = function (res) {
var countPubmed = YAHOO.lang.JSON.parse(res.responseText);
var contentCountPubmed = countPubmed.totalArticleRecords;
callback(contentCountPubmed); //return 15 for example
};
// ...
}
тогда ваш код вызова будет:
getCountArticle("contentCurValue", function(test) {
alert(test);
});
Любое дальнейшее выполнение с использованием значения, возвращенного из вашего AJAX-запроса, будет выполняться внутри вашего метода обратного вызова.
Этот пост SO по сути та же проблема, но не специфичная для YUI: получение неопределенного в javascript при вызове ajax