- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试从我现在运行的 jQuery 中创建一个普通的 JavaScript 函数。我想要做的是等待两个函数从两个不同的 API 请求加载数据。如果两者都是空的,那么我想做一些事情。我现在用 JavaScript 编写了两个请求函数,但我卡在了 .when 部分。我将如何在 JavaScript 中创建它。
代码现在看起来像这样:
function Request1() {
var xhr = new XMLHttpRequest();
xhr.open('GET', 'https://user', true);
xhr.send();
xhr.onreadystatechange = processRequest;
function processRequest(e) {
if (xhr.readyState == 4 && xhr.status == 200) {
var data = JSON.parse(xhr.responseText);
ResultData1 = data;
}
};
return (ResultData1)
}
function Request2() {
var xhr = new XMLHttpRequest();
xhr.open('GET', 'https://gameOrder', true);
xhr.send();
xhr.onreadystatechange = processRequest;
function processRequest(e) {
if (xhr.readyState == 4 && xhr.status == 200) {
var data = JSON.parse(xhr.responseText);
ResultData2 = data;
}
};
return (ResultData2)
}
$.when(Request1(), Request2()).done(function (R1, R2) {
if (ResultData1.length == 0 && ResultData2.length == 0) {
// Do stuff here all works
}
});
我该怎么写呢
最佳答案
使用 XMLHttpRequest
您可以将您的请求包装在 Promise
中并使用 Promise.all
等待所有请求完成。
function request (url) {
var xhr = new XMLHttpRequest();
xhr.open('GET', url, true);
xhr.send();
return new Promise(function (resolve, reject) {
xhr.onreadystatechange = function (e) {
if (xhr.readyState == 4 && xhr.status == 200) {
var data = JSON.parse(xhr.responseText);
resolve(data);
} else if (xhr.readyState == 4) {
reject();
}
};
});
}
Promise.all([
request('https://user'),
request('https://gameOrder')
]).then(function (results) {
var r1 = results[0];
var r2 = results[1];
console.log('Done');
if (r1.length == 0 && r2.length == 0) {
// Do stuff
console.log('Done');
}
}).catch(function () {
console.log('Error');
});
您还可以使用 Fetch API已经返回了一个 promise 。
function getJson (response) {
return response.json();
}
Promise.all([
fetch('https://user').then(getJson),
fetch('https://gameOrder').then(getJson)
]).then(function (results) {
var r1 = results[0];
var r2 = results[1];
console.log('Done');
if (r1.length == 0 && r2.length == 0) {
// Do stuff
console.log('Done');
}
}).catch(function () {
console.log('Error');
});
关于javascript - vanilla JavaScript 当函数完成时,做一些事情,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53517739/
我有一个包含两个项目的解决方案,每个项目都生成一个单独的 dll,供另一个 Windows 应用程序使用。这些项目中的每一个都有一个名为 MyActions 的类,只有一个这样的方法 项目 1
我有一个包含两个项目的解决方案,每个项目都生成一个单独的 dll,供另一个 Windows 应用程序使用。这些项目中的每一个都有一个名为 MyActions 的类,只有一个这样的方法 项目 1
所以我在 if 语句中有这段代码如下 if (!inTime || !moment(inTime).format('m') % 15 === 0) { doSomething(); } 传入的 inT
像往常一样,我想做的比我知道的还多:-D 这就是我正在做的事情......我正在写一篇简历。 但是在简介中,我想要一个“长简介”和一个“短简介”按钮。 长传记显然会显示整个传记,但短传记会捕获列表中的
我正在使用物质。 js创建一个二维场景。我在场景中对一个物体施加力,这个物体撞击其他物体,但最终所有物体都因摩擦和能量损失而停止移动。 我需要以某种方式检测场景中的所有物体何时停止移动。我发现这样
谁能快速浏览一下这段代码,让我知道哪里出错了。 在模糊事件中,.textok 类加载正常,但 .textbad 类加载不正常。 .textok { color:#0F0; background
我的情况是这样的:我有一个项目,它使用了一些生成的代码。在生成的代码中,几乎所有文件中都硬编码了某个 URI。 因此,在某些时候我得到了两个生成的代码库:一个针对开发,另一个针对暂存。 我想通过 Gr
这是一个严肃的问题(见我的评论)。 问题很简单:Java 所做的所有 SEO 不友好的事情有哪些会导致您的网站在主要搜索引擎中的排名不如应有的好? 最佳答案 有一个与 JSESSIONID 相关的 s
我正在使用 PHP。我想完成 jQuery AJAX 进程,(完成进程并数据返回主页后)。 然后执行下一个 jQuery 操作。关于如何做到这一点有什么想法吗? $.ajax({ url: "pa
在释放内存之前,我要从 CPU 缓存中逐出内存范围。理想情况下,我只想放弃这些缓存行而不将它们保存到内存中。因为没有人会使用这些值,无论谁再次获得该内存范围(在 malloc()/new/_mm_ma
我不喜欢 jackson 。 我想使用 ajax,但要使用 Google Gson。 所以我试图弄清楚如何实现我自己的 HttpMessageConverter 以将其与 @ResponseBody
我是一名优秀的程序员,十分优秀!