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

晋江网站建设山东省建设局拖欠工资网站

晋江网站建设,山东省建设局拖欠工资网站,wordpress插件白屏,php做教育网站说明&#xff1a;在实际使用中&#xff0c;重复的请求往往导致数据结果显示错乱&#xff0c;例如&#xff0c;重复请求2次&#xff0c;表格分页展示的是第一次请求的数据。这种情况希望在请求第二次前取消第一次的请求 1、取消重复请求示例 <template> <div>news组…

  说明:在实际使用中,重复的请求往往导致数据结果显示错乱,例如,重复请求2次,表格分页展示的是第一次请求的数据。这种情况希望在请求第二次前取消第一次的请求

1、取消重复请求示例

<template>

  <div>news组件</div>

  <el-button type="primary" @click="handleClick">点击</el-button>

</template>

<script lang="ts" setup>

import axios from "axios";

let url = 'API地址'

let control

const handleClick = () => {

  if(control) {

   control.abort('取消之前的请求')

  }

  control = new AbortController()

  axios.post(url, {

    参数1: "123540",

    参数2: "2025-04-01",

  },{   

    signal: control.signal // 传递 signal,必须要的

  }).then(res => {

    console.log(res)

    control = null

  }).catch(err=>{

    if(axios.isCancel(err)){

      console.log(err.message+'取消请求')

    }else{

      console.log(err + '其他错误')}

  })

}

</script>

 2、封装axios,支持参数自定义取消请求

    2.1封装成request.ts
import axios from 'axios';
import type { AxiosRequestConfig } from 'axios';// 存储pending请求
const pendingMap = new Map<string, AbortController>()// 生成请求key
const generateReqKey = (config: AxiosRequestConfig) => {const { url, method, params, data } = configreturn [url, method, JSON.stringify(params), JSON.stringify(data)].join('&')
}// 取消重复请求
const removePendingRequest = (config: AxiosRequestConfig, cancel: boolean = false) => {const requestKey = generateReqKey(config)if (pendingMap.has(requestKey)) {if (cancel) {pendingMap.get(requestKey)?.abort('取消重复请求')}pendingMap.delete(requestKey)}
}// 创建axios实例
const instance = axios.create({baseURL: 'https://example.cn',timeout: 10000
})// 请求拦截器
instance.interceptors.request.use(config => {// 由于 config 上不存在 cancelDuplicate 属性,这里使用可选链操作符来避免报错// 由于 AxiosRequestConfig 上不存在 cancelDuplicate 属性,我们可以使用类型断言来绕过类型检查const cancelDuplicate = (config as AxiosRequestConfig & { cancelDuplicate?: boolean })?.cancelDuplicate;if (cancelDuplicate === true) { // 默认不开启开启取消重复请求removePendingRequest(config, true)const controller = new AbortController()config.signal = controller.signalpendingMap.set(generateReqKey(config), controller)}return config
})// 响应拦截器
instance.interceptors.response.use(response => {const { config } = responseremovePendingRequest(config)return response.data
}, error => {if (axios.isCancel(error)) {console.log(`请求被取消: ${error.message}`)return Promise.reject(error)}return Promise.reject(error)
})export default instance
2.2 页面使用

只需要传入参数cancelDuplicate: true 就可以取消请求

<template><div><el-button type="primary" @click="handleClick">取消重复请求</el-button></div>
</template>
<script lang="ts" setup>
import request from '@/utils/request'const handleClick = () => {request.post('/aisleep-api/ammsreport/app/report/explain', {uid: "123540",day: "2025-04-01"}, {headers: {"Token": "eyJhbGciOiJIUzUxMiJ9.eyJ1c2VyX2lkIjoxMjM1NDAsInVzZXJfa2V5IjoiYzgxZmJmNmYtMTI4Mi00ZWQyLTlhZGMtM2ZiN2EyMjVjZDFkIiwidXNlcm5hbWUiOiIxMzY3MDAzNjk0NiJ9.teA6bo8aIJhmrTiMdwSVpYcUS_qZrxKk29qlnYz0Zzb184FrbQJyQZhWybDk4vWLKLzmomDA53Wv_INShfXJSA"},cancelDuplicate: true // 开启取消重复请求}).then(res => {console.log(res)}).catch(err => {})
}
const getData = async () => {request.post('/aisleep-api/ammsreport/app/report/explain', {uid: "123540",day: "2025-04-01"}, {headers: {"Token": "eyJhbGciOiJIUzUxMiJ9.eyJ1c2VyX2lkIjoxMjM1NDAsInVzZXJfa2V5IjoiYzgxZmJmNmYtMTI4Mi00ZWQyLTlhZGMtM2ZiN2EyMjVjZDFkIiwidXNlcm5hbWUiOiIxMzY3MDAzNjk0NiJ9.teA6bo8aIJhmrTiMdwSVpYcUS_qZrxKk29qlnYz0Zzb184FrbQJyQZhWybDk4vWLKLzmomDA53Wv_INShfXJSA"},}).then(res => {console.log(res)}).catch(err => {})
}
onMounted(() => {getData()setTimeout(() => {getData()}, 100)
})
</script>
3.3 运行结果

http://www.dtcms.com/a/450534.html

相关文章:

  • 命令行创建https证书详解
  • Linux 基础命令的 7 大核心模块
  • 沐川移动网站建设设计网站私单价格
  • 杭州网站建设 博客南京做网站品牌
  • 大连专业模板网站制作福州网站提升排名
  • AI-RAN 开发者套件,使用指南
  • 网站自动加水印四川哪家网站推广做的好
  • 泸友科技网站购物网站图片素材
  • 汕头建站模板厂家十堰网站建设u2028
  • C语言进阶知识--字符和字符串函数
  • C++中指针传递与引用传递的区别
  • 云南建设局网站首页网页浏览器主要通过ftp协议
  • 网站建设先航科技贵阳制作网站的公司
  • 做网站建设有哪些公司好耒阳住房与建设局网站
  • Helm入门
  • SpringBoot项目搭建
  • 网站导航菜单兰品牌建设助力高质量发展
  • 小游戏网站网址今天的头条新闻
  • 中专网站建设课程东莞网站系统后缀
  • 广州市学校网站建设公司网站html5自适应屏幕大小
  • 网站推广合作花钱做网站注意些什么
  • 上海缔客网站建设公司刚刚
  • C语言入门教程(第1讲):最通俗的C语言常见概念详解与实战讲解
  • 在华图做网站编辑网页设计于制作课程标准
  • 中国建设报社网站建筑工程公司注册资金要求
  • 虚拟麦克风驱动下载,支持将手机话筒映射成PC端麦克风
  • 网站开发整套视频仓库管理erp系统使用
  • 建立网站纯文字版本网页设计代码放图片
  • 公司微信网站建设方案模板下载长沙网站建设案例
  • 四大门户网站排名微信小程序应用开发