【vue3】中断请求、取消请求

一、需求说明

前端调请求接口过程中,主动取消请求

二、流程说明

三、解决方法

1、api文件:封装的接口

javascript 复制代码
import http from "../../http/fetch";
export default {
  /**
   * @description: 请求接口
   * @param {*} data 所需参数
   * @param {CancelToken} [cancelToken] 取消令牌
   * @return {*}
   */
  handleQq(data: any, cancelToken: any) {
    return http({
      url: "/aaa/completions",
      method: "post",
      data: data,
      cancelToken: cancelToken
    });
  },
};

2、vue文件:页面 +js方法

javascript 复制代码
<a-modal
    v-model:visible="resultData.visible"
    :closable="false"
    :maskClosable="false"
    :footer="null"
    :header="null"
    centered
    :width="280"
    :getContainer="() => $refs.modalStyle"
>
        <img src="../assets/images/lod.gif" alt="" class="gif" />
        <div class="mod">请求中,请稍后...</div>
        <div class="tow" @click="deleteOk">取消请求</div>
</a-modal>

1、添加一个cancelTokenSource,创建一个取消令牌源

2、请求完后清空取消令牌源

3、通过cancel()方法取消请求了

javascript 复制代码
import http from "@/api文件路径";
const { handleQq } = http;
import axios from "axios";

// 创建取消控制器
let resultData = reactive({
    visible:false,// 请求中的标识弹窗,有一个可以点击取消请求按钮
    tokenSource: { cancelTokenSource: null as null | any }
})

/**
 * @description: 调用接口
 * @return {*}
 */
const handleWit = async () => {
    resultData.visible = true;
      resultData.tokenSource.cancelTokenSource = axios.CancelToken.source(); // 添加一个cancelTokenSource,创建一个取消令牌源
    let parm = { model: "deepseek" };
    const { data } = await handleQq(parm, resultData.tokenSource.cancelTokenSource.token);
    if (data) {
        console.log("请求成功")
    } else {
      message.warning("请求失败");
    }
    resultData.visible = false;
  resultData.tokenSource.cancelTokenSource = null; // 请求完后清空取消令牌源
};

/**
 * @description: 取消请求
 * @return {*}
 */
const deleteOk = () => {
  resultData.visible = false;
  if (resultData.tokenSource.cancelTokenSource) {
    resultData.tokenSource.cancelTokenSource.cancel("用户取消识别"); // 通过cancel()方法就可以取消请求了
  }
};

四、参考链接

vue3中怎么中断正在请求的接口,取消请求-CSDN博客

vue如何中断请求 • Worktile社区

相关推荐
张晓~1833994812135 分钟前
数字人源码部署流程分享--- PC+小程序融合方案
javascript·小程序·矩阵·aigc·文心一言·html5
爱喝水的小周38 分钟前
AJAX vs axios vs fetch
前端·javascript·ajax
Jinxiansen021140 分钟前
unplugin-vue-components 最佳实践手册
前端·javascript·vue.js
几道之旅44 分钟前
介绍electron
前端·javascript·electron
周胡杰1 小时前
鸿蒙arkts使用关系型数据库,使用DB Browser for SQLite连接和查看数据库数据?使用TaskPool进行频繁数据库操作
前端·数据库·华为·harmonyos·鸿蒙·鸿蒙系统
31535669131 小时前
ClipReader:一个剪贴板英语单词阅读器
前端·后端
玲小珑1 小时前
Next.js 教程系列(十一)数据缓存策略与 Next.js 运行时
前端·next.js
qiyue771 小时前
AI编程专栏(三)- 实战无手写代码,Monorepo结构框架开发
前端·ai编程
轻语呢喃1 小时前
React智能前端:从零开始的识图学单词项目(一)
javascript·react.js·aigc
断竿散人1 小时前
JavaScript 异常捕获完全指南(下):前端框架与生产监控实战
前端·javascript·前端框架