首页 > 文章列表 > 在使用Tampermonkey脚本时,通过`GM_xmlhttpRequest`依次获取多个链接的GET请求结果并进行条件判断,可以通过递归或回调的方式来实现。以下是一个示例代码,展示了如何实现这一功能: ```javascript // 定义要请求的URL列表 const urls = [ 'https://example.com/api/1', 'https://example.com/api/2', 'https://example.com/api/3' ]; // 初始

在使用Tampermonkey脚本时,通过`GM_xmlhttpRequest`依次获取多个链接的GET请求结果并进行条件判断,可以通过递归或回调的方式来实现。以下是一个示例代码,展示了如何实现这一功能: ```javascript // 定义要请求的URL列表 const urls = [ 'https://example.com/api/1', 'https://example.com/api/2', 'https://example.com/api/3' ]; // 初始

159 2025-03-24

在使用Tampermonkey脚本时,如何通过GM_xmlhttpRequest依次获取多个链接的GET请求结果并进行条件判断?

使用Tampermonkey脚本,如何利用GM_xmlhttpRequest依次发起多个GET请求,并根据返回结果进行条件判断,是一个常见问题。关键在于:获取单个请求结果后立即判断,满足条件则停止后续请求,否则继续下一个。 之前的方案往往在所有请求完成后才进行判断,效率低下。

本文提供两种改进方案:

方法一:依次请求,逐个判断

此方法保证每个请求完成后立即判断,满足条件则结束。可以使用递归或迭代实现。以下示例使用模拟Promise简化演示:

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不支持取消请求,只能忽略后续结果。以下为简化示例:

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()));
  for (let i = 0; i < results.length; i++) {
    if (results[i].data.indexOf('#') > -1) {
      return { successIndex: i, data: results[i].data };
    }
  }
  return '未找到符合条件的请求';
}

mainRequest([Promise1, Promise2, Promise3]).then(result => {
  console.log('result:', result);
});

优点:更快找到符合条件的结果;缺点:无法取消已发出的请求,可能造成资源浪费。

选择哪种方法取决于具体需求。 如果请求数量较少,且每个请求时间较长,方法一更合适;如果请求数量较多,且每个请求时间较短,方法二效率更高,但需要权衡资源消耗。 实际应用中,需将模拟Promise替换为GM_xmlhttpRequest

来源:1741905987