从 AJAX 请求中获取有序响应
Getting Ordered Responses from AJAX Request
在这段代码中,我在 for 循环中将单个单词发送到 google translate,并尝试将来自 google translate API 的翻译响应与原始单词配对.但是,在这样做的过程中,我也渐渐明白了异步和同步的区别!
现在的问题是以某种方式继续利用异步 AJAX 调用的效率,但以某种方式以我发送给 google 翻译的原始顺序捕获翻译。
for (word in original_text) {
$.ajax({
type: "GET",
url: "https://www.googleapis.com/language/translate/v2?",
data: {key: my_Key, source: "en", target: "es", q: original_text[word]},
dataType: 'json',
success: function (result, status, xhr) {
translated.push(result.data.translations[0].translatedText);
alert(translated);
if (translated.length === original_text.length) {
var merged = {};
for (word in original_text) {
merged[original_text[word]] = translated[word];
}
dfrd.resolve(JSON.stringify(merged));
}
},
error: function (xhr, status, errorMsg) {
alert(xhr.status + "::" + xhr.statusText + "::" + xhr.responseText);
}
});
基本上,Promises.all() 可以让你做这样的事情:
var promises = [];
for(var i = 0; i < 5; i++){
promises.push($.ajax("SomeURL"));
}
Promise.all(promises).then(function(datas){
for(var y = 0; y < datas.length; y++){
var data = datas[y]; //Your data in correct order
}
});
您可以根据自己的情况进行调整。主要思想 - 收集到一个数组然后 - 使用 promise.all
在这段代码中,我在 for 循环中将单个单词发送到 google translate,并尝试将来自 google translate API 的翻译响应与原始单词配对.但是,在这样做的过程中,我也渐渐明白了异步和同步的区别!
现在的问题是以某种方式继续利用异步 AJAX 调用的效率,但以某种方式以我发送给 google 翻译的原始顺序捕获翻译。
for (word in original_text) {
$.ajax({
type: "GET",
url: "https://www.googleapis.com/language/translate/v2?",
data: {key: my_Key, source: "en", target: "es", q: original_text[word]},
dataType: 'json',
success: function (result, status, xhr) {
translated.push(result.data.translations[0].translatedText);
alert(translated);
if (translated.length === original_text.length) {
var merged = {};
for (word in original_text) {
merged[original_text[word]] = translated[word];
}
dfrd.resolve(JSON.stringify(merged));
}
},
error: function (xhr, status, errorMsg) {
alert(xhr.status + "::" + xhr.statusText + "::" + xhr.responseText);
}
});
基本上,Promises.all() 可以让你做这样的事情:
var promises = [];
for(var i = 0; i < 5; i++){
promises.push($.ajax("SomeURL"));
}
Promise.all(promises).then(function(datas){
for(var y = 0; y < datas.length; y++){
var data = datas[y]; //Your data in correct order
}
});
您可以根据自己的情况进行调整。主要思想 - 收集到一个数组然后 - 使用 promise.all