542

この質問は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

その値を返そうとすると、「未定義」になります。私はSOからのいくつかのアイデアに従いましたが、それでも失敗します。

それらは:

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

3 に答える 3

530

同期メソッド内の非同期呼び出しから戻ることができないため、これは不可能です。

この場合、戻り値を受け取る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
});

重要なのは、内部関数呼び出しが非同期である場合、応答を「返す」ためには、この呼び出しを「ラップ」するすべての関数も非同期である必要があるということです。

コールバックがたくさんある場合は、思い切ってQのようなpromiseライブラリを使用することを検討してください。

于 2011-07-27T16:15:48.510 に答える
32

コールバックから値を返すことは意味がありません。代わりに、コールバックで実行したい「foo()」作業を実行します。

非同期コールバックは、イベントが発生したときにブラウザまたはGoogleジオコーディングライブラリなどのフレームワークによって呼び出されます。戻り値を表示する場所はありません。つまり、コールバック関数は値を返すことができますが、関数を呼び出すコードは戻り値に注意を払いません。

于 2011-07-27T16:13:13.507 に答える
16

jQueryを使用している場合は、これを試してみることをお勧めします:http: //api.jquery.com/category/deferred-object/

これにより、ajaxリクエスト(または非同期操作)が完了するまで、コールバック関数の実行を延期することができます。これは、いくつかのajaxリクエストがすべて完了した後にコールバックを呼び出すためにも使用できます。

于 2011-07-27T17:35:55.813 に答える