0

我无法在 PHP 中发送两个请求并等待两个答案。这是我的代码:

        function getXDomainRequest() {
            var xdr = null;

            if (window.XDomainRequest) {
                xdr = new XDomainRequest();
            } else if (window.XMLHttpRequest) {
                xdr = new XMLHttpRequest({mozSystem: true});
            } else {
                alert("Your browser does not support AJAX");
            }

            return xdr;
        }

        function sendData() {
            var json1= "";
            var json2= "";

            var xdr = getXDomainRequest();
            xdr.onload = function() {
                json1 = xdr.responseText;
            }

            var xdr2 = getXDomainRequest();
            xdr2.onload = function() {
                json2 = xdr2.responseText;
            }

            var Id = document.querySelector('#searchField').value;
            // Call API
            xdr.open("GET", "./dorequest.php?id=" + Id + "&requesttype=player");
            xdr.send();

            xdr2.open("GET", "./dorequest.php?id=" + Id + "&requesttype=stats");
            xdr2.send();

            xdr.wait();
            // Display results
            getHtmlResults(jsonPlayer, jsonStats);
        }

正如预期的那样,json1and在被调用json2时仍然是空getHtmlResults的。我可以通过调用 in the 和我的 final 函数来同步xdr2.send()执行xdr.onload此操作,xdr2.onload但我想异步执行此操作以获得更好的响应时间。

谢谢 !

(欢迎对代码进行任何其他评论我对 php 很陌生 :))

编辑 :

所以我尝试使用 Ajax,它似乎工作:)

            var jsonPlayer = "";
            var jsonStats = "";
            var steamId = document.querySelector('#searchField').value;
            $.when(
                $.ajax({url: "./dorequest.php?steamid=" + steamId + "&requesttype=playersummary",
                        success: function(response){ jsonPlayer = response; }}),
                $.ajax({url: "./dorequest.php?steamid=" + steamId + "&requesttype=csgostats",
                        success: function(response){ jsonStats = response; }}) ).done(
                function(player, stats) {
                            getHtmlResults(player, stats);
                        });
4

2 回答 2

0

您可以发送两个调用 ASync 并在两个 .onload 中都有一个函数来检查另一个请求是否已完成。因此,一旦其中一个 onload 发现另一个 onload 完成,您就可以调用 getHtmlResults 函数。

于 2014-07-11T18:19:44.753 回答
0

Promise通常用作处理异步进程的抽象。

将您的 AJAX 调用包装在 Promise 中以执行以下操作:

var ajax1 = request("stats");
var ajax2 = request("player");
when(ajax1, ajax2).done(function (stats, player) {
    console.log(stats, player);
});

大多数流行的框架都有一个内置的Promise API。

于 2014-07-11T18:20:02.197 回答