如何从异步回调函数返回值?

Gow*_*wri 440 javascript asynchronous callback javascript-objects

在SO中多次询问这个问题.但我还是得不到东西.

我想从回调中获得一些价值.请查看下面的脚本以获得说明.

function foo(address){

      // google map stuff
      geocoder.geocode( { 'address': address}, function(results, status) {
          results[0].geometry.location; // I want to return this value
      })

    }
    foo(); //result should be results[0].geometry.location; value
Run Code Online (Sandbox Code Playgroud)

如果我试图返回该值只是"未定义".我从SO那里听了一些想法,但仍然失败了.

那些是:

function foo(address){
    var returnvalue;    
    geocoder.geocode( { 'address': address}, function(results, status) {
        returnvalue = results[0].geometry.location; 
    })
    return returnvalue; 
}
foo(); //still undefined
Run Code Online (Sandbox Code Playgroud)

Sea*_*sey 446

这是不可能的,因为您无法从同步方法内的异步调用返回.

在这种情况下,您需要将回调传递给将接收返回值的foo

function foo(address, fn){
  geocoder.geocode( { 'address': address}, function(results, status) {
     fn(results[0].geometry.location); 
  });
}

foo("address", function(location){
  alert(location); // this is where you get the return value
});
Run Code Online (Sandbox Code Playgroud)

问题是,如果内部函数调用是异步的,那么所有函数"包装"此调用也必须是异步的,以便"返回"响应.

如果你有很多回调,你可以考虑采取措施并使用像Q这样承诺库.

  • :)它不强,它就是这样的.只要使用异步方法传递数据,整个函数链就会变为异步. (4认同)
  • *"你不能在同步方法中使用异步调用."* - 是的,你可以.您无法在同一同步方法中使用异步调用的结果. (4认同)
  • @Sean Kinsey,你能告诉我如何访问foo()函数外的位置变量吗? (3认同)
  • Upvote最终使这有意义. (2认同)

Poi*_*nty 22

从回调中返回值是没有意义的.相反,回调中执行"foo()"工作.

当事件发生时,浏览器或某些框架(如Google地理编码库)会调用异步回调.没有返回值的地方.换句话说,回调函数可以返回一个值,但调用该函数的代码不会注意返回值.


Ale*_*eyd 15

如果你碰巧使用jQuery,你可能想要试一试:http: //api.jquery.com/category/deferred-object/

它允许您推迟回调函数的执行,直到完成ajax请求(或任何异步操作).一旦几个ajax请求全部完成,这也可用于调用回调.