我在使用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);
}
正如预期的那样,json1
和json2
在调用getHtmlResults
时仍为空。我可以通过将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);
});
答案 0 :(得分:0)
你可以发送两个调用ASync并在.onload中都有一个函数来检查另一个请求是否已经完成。因此,只要其中一个onload发现另一个onload完成,就可以调用getHtmlResults函数。
答案 1 :(得分:0)
Promises 通常用作处理异步进程的抽象。
将你的AJAX调用包含在Promise中:
var ajax1 = request("stats");
var ajax2 = request("player");
when(ajax1, ajax2).done(function (stats, player) {
console.log(stats, player);
});
大多数流行的框架都有内置的Promise API。