9

こんにちは、AJAX 応答を 2 つの変数 x と y または配列に格納する必要があります。私の AJAX 応答は配列です。私はデータを見ることができますが、che call でのみ警告します。ajax 呼び出し以外のデータが必要です

var x;
var y;

$.ajax({
    url: 'ajaxload.php',
    dataType: "json",
    success: function (data) {
        x = data.posX;
        y = data.posX;
        alert(x + " " + y);  // I can se data but I need outside ajax call
    }
});
4

4 に答える 4

34

私の理解が正しければ、後でコード内で ajax レスポンスを再利用したいと思うでしょう。その場合、デフォルトでは JavaScript エンジンは ajax リクエストの応答を待機しないため、現在のコードは機能しません。つまり、以下のコードは機能しません。

<script type="text/javascript">
$(document).ready(function(){
    var x; 
    var y;
    $.ajax({
        url: 'ajaxload.php',
        dataType: "json", 
        success: function(data) { 
            x= data.posX;
            y= data.posX;
            alert (x+" "+y);  // I can se data but I need outside ajax call
        }
    });
    alert(x+" "+y); // You won't see anything, because this data isn't yet populated. The reason for this is, the "success" function is called when the ajax request has finished (it has received a response).
})
</script>

ajax の応答を待つ必要があります。jQuery でこれを行うには、コードを少し変更する必要があります。

<script type="text/javascript">
$(document).ready(function(){
    var data = $.parseJSON($.ajax({
        url:  'ajaxload.php',
        dataType: "json", 
        async: false
    }).responseText); // This will wait until you get a response from the ajax request.

    // Now you can use data.posX, data.posY later in your code and it will work.
    var x = data.posX;
    var y = data.posY;
    alert(x+" "+y);
    alert(data.posX+" "+data.posY);
});
</script>
于 2012-10-22T12:41:53.527 に答える
22

他のJavaScript関数でさらに使用するために、ajax応答をグローバル配列に保存できます

var ajaxResult=[];

$(document).ready(function(){

  $.ajax({
    url: 'ajaxload.php',
    async:true,
    dataType: "json", 
    success: function(data)
     { 
        ajaxResult.push(data);
     }
  });
});

otherJsfunc()
 {
  console.log(ajaxResult); 
 }
于 2014-05-24T06:58:20.140 に答える
0

変数をデカルすると、ajax の外側の値にアクセスできます。

例えば:

<script type="text/javascript">
   var x = '';
   var y = '';

   function sendAjax()
   {
        // your ajax call
        x= data.posX;
        y= data.posX;  
   } 
   sendAjax();
</script>

ajax がうまく機能する場合は、変数xyにグローバルにアクセスできます。

于 2012-10-22T12:25:49.940 に答える
0

このコードをドキュメント対応ハンドラー内で実行している場合、x 変数と y 変数は完全にグローバルではありません。試すwindow.x=''; window.y='';

于 2012-10-22T12:27:32.583 に答える