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

网站搭建申请域名查询站长工具

网站搭建申请,域名查询站长工具,帮其他企业做网站属于外包公司吗,舆情分析研判报告XHR / Fetch / Axios 请求的取消请求与请求重试是前端性能优化与稳定性处理的重点,也是面试高频内容。下面是这三种方式的详解封装方案(可直接复用)。 ✅ 一、Axios 取消请求与请求重试封装 1. 安装依赖(可选,用于扩展…

XHR / Fetch / Axios 请求的取消请求请求重试是前端性能优化与稳定性处理的重点,也是面试高频内容。下面是这三种方式的详解封装方案(可直接复用)。


✅ 一、Axios 取消请求与请求重试封装

1. 安装依赖(可选,用于扩展)

npm install axios

2. 封装 cancelToken 与 retry 的 axios 请求模块

// axiosRequest.js
import axios from 'axios'const pendingMap = new Map()// 生成唯一 key(用于标记请求)
function getRequestKey(config) {const { method, url, params, data } = configreturn [method, url, JSON.stringify(params), JSON.stringify(data)].join('&')
}// 添加请求到 pendingMap
function addPending(config) {const key = getRequestKey(config)config.cancelToken = new axios.CancelToken(cancel => {if (!pendingMap.has(key)) {pendingMap.set(key, cancel)}})
}// 移除请求
function removePending(config) {const key = getRequestKey(config)if (pendingMap.has(key)) {const cancel = pendingMap.get(key)cancel && cancel()pendingMap.delete(key)}
}// 重试机制封装
function retryAdapterEnhancer(adapter, options = {}) {const { retries = 3, delay = 1000 } = optionsreturn async config => {let retryCount = 0const request = async () => {try {return await adapter(config)} catch (err) {if (retryCount < retries) {retryCount++await new Promise(res => setTimeout(res, delay))return request()} else {return Promise.reject(err)}}}return request()}
}// 创建实例
const axiosInstance = axios.create({timeout: 5000,adapter: retryAdapterEnhancer(axios.defaults.adapter, { retries: 2, delay: 1000 })
})// 请求拦截器
axiosInstance.interceptors.request.use(config => {removePending(config)addPending(config)return config
})// 响应拦截器
axiosInstance.interceptors.response.use(response => {removePending(response.config)return response},error => {if (axios.isCancel(error)) {console.warn('Request canceled:', error.message)}return Promise.reject(error)}
)export default axiosInstance

✅ 使用示例:

import request from './axiosRequest'request.get('/api/data', { params: { id: 1 } }).then(res => console.log(res)).catch(err => console.error(err))

✅ 二、Fetch 封装(支持取消请求 & 重试)

1. 使用 AbortController 封装取消与重试

// fetchRequest.js
export function fetchWithRetry(url, options = {}, retries = 3, delay = 1000) {const controller = new AbortController()options.signal = controller.signalconst fetchData = (retryCount = 0) => {return fetch(url, options).then(res => {if (!res.ok) throw new Error('Network response was not ok')return res}).catch(err => {if (retryCount < retries && err.name !== 'AbortError') {return new Promise(resolve =>setTimeout(() => resolve(fetchData(retryCount + 1)), delay))}throw err})}return {promise: fetchData(),cancel: () => controller.abort()}
}

✅ 使用示例:

const { promise, cancel } = fetchWithRetry('/api/data', {}, 2, 1000)promise.then(res => res.json()).then(data => console.log(data)).catch(err => console.error(err))// 调用 cancel() 可随时取消请求

✅ 三、XHR 原生封装(带取消 & 重试)

// xhrRequest.js
export function xhrWithRetry({ url, method = 'GET', data = null, retries = 3, delay = 1000 }) {let xhr = nullconst send = (retryCount = 0, resolve, reject) => {xhr = new XMLHttpRequest()xhr.open(method, url, true)xhr.onreadystatechange = () => {if (xhr.readyState === 4) {if (xhr.status >= 200 && xhr.status < 300) {resolve(xhr.responseText)} else if (retryCount < retries) {setTimeout(() => send(retryCount + 1, resolve, reject), delay)} else {reject(new Error(`Request failed: ${xhr.status}`))}}}xhr.onerror = () => reject(new Error('Network Error'))xhr.send(data)}const promise = new Promise((resolve, reject) => send(0, resolve, reject))return {promise,cancel: () => xhr && xhr.abort()}
}

✅ 使用示例:

const { promise, cancel } = xhrWithRetry({ url: '/api/data' })promise.then(res => console.log(res)).catch(err => console.error(err))// 可随时调用取消
cancel()

✅ 总结对比

特性/方式取消支持重试支持易用性推荐场景
Axios✔️ CancelToken✔️ 自定义 adapter✅ 最佳Vue/React 项目
Fetch✔️ AbortController✔️ 手动封装✅ 清晰原生 / SSR 项目
XHR✔️ abort()✔️ 手动封装❌ 复杂老旧兼容需求

如果你想把这三套方案整合成一个通用库或 TypeScript 模块,我也可以帮你封装成统一接口版本。是否需要我继续处理这部分?

http://www.dtcms.com/wzjs/345354.html

相关文章:

  • 商务网站页面设计技术网址域名注册信息查询
  • 宁波网站建设设计公司网络推广学校
  • 哪家网站建设b站暴躁姐
  • 如何创建自己公司的网站长沙seo网站优化
  • 税务网站建设汇报优化设计四年级上册语文答案
  • 创意设计赛道具体赛题是什么网站seo优化推广外包
  • 网站建设咨询问卷电商网站
  • 中国全球门户网站网店怎么推广和宣传
  • 河南省建设厅证件证件查询网站中国十大网站
  • 网站更改公司需要重新备案吗济南新站seo外包
  • 阳泉移动网站建设百度公司的企业文化
  • 360打不开建设银行的网站兰州网络推广与营销
  • 网站友情链接怎么添加上海网络推广排名公司
  • 网站集约化建设推进情况企业邮箱查询
  • 德州做网站最好的公司有哪些做任务赚佣金一单10块
  • 为什么无法再社保网站上做减员搜狗推广
  • 网站上的广告位是怎么做的搜索广告排名
  • 博彩网站自己做竞价托管信息
  • 如何做盗版小说网站静态网页设计与制作
  • 做旅游网站的目的与意义核心关键词和长尾关键词举例
  • 洪梅网站建设公司深圳外贸网站推广
  • 阿里云建设网站买哪个服务设计公司取名字大全集
  • 深圳有实力的网站建设服务商百度小说app下载
  • 公司介绍模板免费陕西seo主管
  • 做网站时怎么插入视频搭建一个app平台需要多少钱
  • 泰安网页设计招聘网站怎么优化到首页
  • 苏州网站建设推荐好先生科技免费s站推广网站
  • 怎么做网站的地图页各种网站
  • 网站设计的用途免费注册网站
  • 帝国cms7.0网站地图网络营销工程师