使用JS,写了一个轮询发送请求的工具。
// 导入axios,这是一个基于promise的HTTP客户端,用于发送请求
import axios from 'axios';
// 轮询的配置对象
const pollConfig = {
requests: [], // 请求数组,包含请求的url和方法
interval: 5000, // 轮询间隔,单位毫秒
stopCondition: () => false, // 停止轮询的条件,返回true时停止
};
// 轮询发送请求的函数
function pollRequests(config) {
const { requests, interval, stopCondition } = config;
let intervalId;
// 执行请求并处理响应的函数
function makeRequest(request) {
axios(request).then(response => {
console.log('请求成功:', response);
// 根据响应处理逻辑
// ...
// 如果没有满足停止条件,继续轮询
if (!stopCondition()) {
intervalId = setTimeout(makeRequest, interval, request);
} else {
clearTimeout(intervalId);
console.log('停止轮询');
}
}).catch(error => {
console.error('请求失败:', error);
// 错误处理逻辑
// ...
// 如果没有满足停止条件,继续轮询
if (!stopCondition()) {
intervalId = setTimeout(makeRequest, interval, request);
} else {
clearTimeout(intervalId);
console.log('停止轮询');
}
});
}
// 开始轮询
requests.forEach(request => {
makeRequest(request);
});
}
// 使用示例
pollRequests(pollConfig);
这段代码定义了一个名为pollRequests
的函数,它接收一个配置对象作为参数,该对象包含轮询的请求数组、间隔时间以及停止轮询的条件。函数内部使用setTimeout
进行轮询,并通过axios
发送HTTP请求。如果响应成功,它会根据响应执行相关逻辑;如果发生错误,它会执行错误处理逻辑。如果满足停止轮询的条件,它会清除定时器并输出相应的日志信息。这个例子展示了如何使用JavaScript编写一个简单的轮询请求发送工具。
评论已关闭