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

网站假网站这么做网站维护需要多少钱

网站假网站这么做,网站维护需要多少钱,泸州建设网站,html网站开发语言说明&#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/492746.html

相关文章:

  • 360网站页面的工具栏怎么做网站功能的介绍
  • 各大免费推广网站做影视网站犯法吗
  • 天台网站建设网站建设电话着么打
  • iphone网站外贸行业网络推广
  • 做网站编程的待遇深圳网站设计哪家快
  • 网站建设平台信息网站制作软件叫什么
  • 自己做的美食分享到网站重庆网站建设套餐
  • 给公司制作网站吗海外推广引流
  • 项目网站分析手机页面制作代码
  • 屏蔽右键网站wordpress跳转页面不停止音乐
  • go-swagger标准接口暴露
  • 我是在百度上搜广东网站建设网站开发主要语言
  • 网站卡密怎么做园区网络建设方案
  • 西安哪有做网站的建设网站找哪个公司
  • 网站建设实训报告总结wordpress搬家 图片不显示
  • 网站域名查询网学编程要什么学历
  • 业网站制作做网站的网站违不违法
  • 百度上网站怎么做ppt精美模板
  • 网站排名需要多长时间免费咨询图片带字
  • 做照片的网站查做外贸客户的网站
  • 枣庄学习建设网站培训网页制作与设计教材
  • 三目云台摄像头识别输电线路
  • 个人网站免费域名注册建设网站等于网络营销吗
  • HTB Driver wp
  • 网站优化需要什么软件公司网站怎么管理
  • 可以做网站的语言平面设计做网站的步骤
  • 网站建设分为什么建设网站最重要的是什么
  • 电商网站新闻怎么做的宿迁网站搭建
  • 红帽RH134知识复习(3)
  • 成都电子网站建设多少钱投资集团网站建设方案