当前位置: 代码网 > it编程>前端脚本>Vue.js > 在Tampermonkey中如何使用GM_xmlhttpRequest实现对多个链接的并发请求,并在获取到符合条件的结果后停止后续请求?

在Tampermonkey中如何使用GM_xmlhttpRequest实现对多个链接的并发请求,并在获取到符合条件的结果后停止后续请求?

2025年03月30日 Vue.js 我要评论
本文探讨如何在tampermonkey中利用gm_xmlhttprequest实现对多个链接的并发请求,并在满足特定条件时终止后续请求。 文中将介绍两种方法,并分析其优缺点。您之前尝试使用promi

在tampermonkey中如何使用gm_xmlhttprequest实现对多个链接的并发请求,并在获取到符合条件的结果后停止后续请求?

本文探讨如何在tampermonkey中利用gm_xmlhttprequest实现对多个链接的并发请求,并在满足特定条件时终止后续请求。 文中将介绍两种方法,并分析其优缺点。您之前尝试使用promise.race()和promise.all()但未能实现按条件终止,本文将提供改进方案。

方法一:顺序请求

此方法依次发起请求,每个请求完成后检查结果是否符合条件,符合则停止后续请求。 以下示例使用settimeout模拟网络请求:

function promise1() {
  return new promise((resolve) => {
    settimeout(() => {
      resolve({ data: '123' });
    }, 2000);
  });
}

function promise2() {
  return new promise((resolve) => {
    settimeout(() => {
      resolve({ data: '#234' });
    }, 2000);
  });
}

function promise3() {
  return new promise((resolve) => {
    settimeout(() => {
      resolve({ data: '1' });
    }, 2000);
  });
}

async function mainrequest(promises) {
  for (const promise of promises) {
    const result = await promise();
    if (result.data.indexof('#') > -1) {
      return result.data;
    }
  }
  return '全部不符合条件';
}

mainrequest([promise3, promise2, promise1]).then((result) => {
  console.log('result', result);
});
登录后复制

此方法确保满足条件后立即停止,但请求顺序执行,整体耗时可能较长。

方法二:并发请求

此方法并发发起所有请求,但gm_xmlhttprequest缺乏原生取消请求机制,因此我们使用promise管理请求状态,在获取到符合条件的结果后立即返回结果,后续请求继续执行但结果被忽略。

function promise1() {
  return new promise((resolve) => {
    settimeout(() => {
      resolve({ data: '#123' });
    }, math.random() * 1000);
  });
}

function promise2() {
  return new promise((resolve) => {
    settimeout(() => {
      resolve({ data: '#234' });
    }, math.random() * 1000);
  });
}

function promise3() {
  return new promise((resolve) => {
    settimeout(() => {
      resolve({ data: '#1' });
    }, math.random() * 1000);
  });
}


async function mainrequest(promises) {
  const results = await promise.all(promises.map(p => p().catch(e => null))); // 捕获错误
  for (let i = 0; i < results.length; i++) {
    if (results[i] && results[i].data.indexof('#') > -1) {
      return { successindex: i, data: results[i].data };
    }
  }
  return '未找到符合条件请求';
}

mainrequest([promise1, promise2, promise3]).then((result) => {
  console.log('result', result);
});
登录后复制

此方法并发请求,效率较高,但无法真正中断后续请求,仅忽略其结果。 实际应用中,需根据具体需求选择合适的方法。 请注意,以上代码使用settimeout模拟gm_xmlhttprequest,实际应用中需替换为gm_xmlhttprequest代码。 此外,错误处理也得到了增强,使用.catch()捕获可能的错误。

以上就是在tampermonkey中如何使用gm_xmlhttprequest实现对多个链接的并发请求,并在获取到符合条件的结果后停止后续请求?的详细内容,更多请关注代码网其它相关文章!

(0)

相关文章:

版权声明:本文内容由互联网用户贡献,该文观点仅代表作者本人。本站仅提供信息存储服务,不拥有所有权,不承担相关法律责任。 如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 2386932994@qq.com 举报,一经查实将立刻删除。

发表评论

验证码:
Copyright © 2017-2025  代码网 保留所有权利. 粤ICP备2024248653号
站长QQ:2386932994 | 联系邮箱:2386932994@qq.com