How to use YAHOO.util.Connect.asyncRequest and return results?

痞子三分冷 提交于 2020-01-13 11:08:39

问题


I'm using YAHOO.util.Connect.asyncRequest to get data from database, here is the code :

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);

}

I would like this function return : "contentCurValue" (eg:15), but when I try to use this code I get "undefined" :

var test = getCountArticle();
alert(test); // return undefined, should return 15

My error is probably due to asynchronous query, but how can I force "var test = getCountArticle();" to wait for results ?


回答1:


Since the call is by nature asynchronous, rather than try to wait for the response, you would be better off specifying a callback function to execute with the data. You could modify your method like this:

 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
  };
  // ...
} 

then your calling code would be:

 getCountArticle("contentCurValue", function(test) {
    alert(test);
}); 

Any further execution using the value returned from your AJAX query would proceed inside of your callback method.

This SO post is essentially the same problem, but not YUI specific: Getting undefined in javascript when calling ajax



来源:https://stackoverflow.com/questions/3159368/how-to-use-yahoo-util-connect-asyncrequest-and-return-results

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!