当前位置: 首页 > news >正文

js fetch请求中断的几种方式

1、通过AbortController

这是官方标准手段,真正意义的阻止请求(不支持ie)

后端接口设置的两秒返回数据

function myFetch() {const controller = new AbortController();const signal = controller.signal;fetch('http://localhost:3000/aaa/bbb', {method: 'post',signal,headers: {'Content-Type': 'application/json'}}).then(res => res.json()).then(res => {console.log(res);return res;}).catch(e => {console.log(e);})// setTimeout(()=> {//     controller.abort();// }, 1000)
}

默认结果:
在这里插入图片描述
解开定时器后:
![在这里插入图片描述](https://img-blog.csdnimg.cn/49a12cad0df74597a88e34d1a1d027b4.png

在这里插入图片描述

2、模拟中断

通过promise,成功用resolve返回,失败用reject返回(浏览器上,请求依然会发出,并得到响应)
第一种方法:

function getData() {return new Promise((resolve, reject) => {myFetch().then(res => {resolve(res);});setTimeout(() => {reject({code: '500',msg: '请求失败'})}, 1000);})
}async function gotData() {try {const data = await getData();console.log(data);} catch (error) {console.log(error);}
}
gotData();

运行结果:
在这里插入图片描述
第二种方法:

function getData() {let myReject = null;let myPromise = new Promise((resolve, reject) => {myReject = reject;myFetch().then(res => {resolve(res);});});myPromise.abort = () => myReject({code: '500',msg: '请求失败'});return myPromise;
}async function gotData() {const result = getData();result.then(res => {console.log(res);}).catch(e => {console.log(e);})setTimeout(() => {result.abort();}, 1000);
}
gotData();
http://www.lryc.cn/news/130105.html

相关文章:

  • Python自动化实战之使用Selenium进行Web自动化详解
  • “之江数据安全治理论坛”暨《浙江省汽车数据处理活动规定(专家建议稿)》研讨会顺利召开
  • 消息中间件面试题
  • 麻辣烫数据可视化,麻辣烫市场将持续蓬勃发展
  • 大数据课程J1——Scala的概述
  • 第二章:25+ Python 数据操作教程(第十三节NUMPY 教程与练习)
  • 【Java面试】如果一个线程两次调用start(),会出现什么问题?
  • 购买steam余额有风险吗?以及N种被红锁的情况
  • 使用 BERT 进行文本分类 (02/3)
  • 基于Hadoop的表级监管
  • 【学习日记】【FreeRTOS】延时列表的实现
  • ​LeetCode解法汇总833. 字符串中的查找与替换
  • ide internal errors【bug】
  • 阿里云与中国中医科学院合作,推动中医药行业数字化和智能化发展
  • 【Redis】Redis 的学习教程(五)之 SpringBoot 集成 Redis
  • github以及上传代码处理
  • 【PACS源码】认识PACS的架构和工作流程
  • 【C++】开源:跨平台Excel处理库-libxlsxwriter配置使用
  • 前端-轮询
  • Python “贪吃蛇”游戏,在不断改进中学习pygame编程
  • Linux网络编程_Ubuntu环境配置安装
  • gradle java插件
  • 神经网络基础-神经网络补充概念-48-rmsprop
  • 分析Flink,源和算子并行度不一致时,运行一段时间后,看似不再继续消费的问题,提供解决思路。
  • PyTorch训练深度卷积生成对抗网络DCGAN
  • Spring-4-掌握Spring事务传播机制
  • [PyTorch][chapter 49][创建自己的数据集 1]
  • 中间件(二)dubbo负载均衡介绍
  • springboot异步文件上传获取输入流提示找不到文件java.io.FileNotFoundException
  • 安装jenkins-cli