前端优化请求

本文介绍了前端如何通过setTimeout、无缓存设置、axios取消Token、URL时间戳等方式降低请求频率,并详细讲解了如何使用axios的CancelToken取消请求。同时,探讨了在实际项目中利用HTTP2等协议进行优化的可能。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

虽然前端频繁请求不是很好,但是有些需求也是没办法。今天说下前端怎么处理请求优化

1.通过setTimeout来缓解请求频率

2.设置无缓存

html文件设置meta头部

<meta http-equiv="pragma" content="no-cache">
<meta http-equiv="cache-control" content="no-cache, no-store, must-revalidate">

接口请求时设置header头 

headers: {'Cache-Control': 'no-store' }

3.axios可通过CancelToken,将在pending的接口去掉

import axios from "axios";
var CancelToken = axios.CancelToken;
var cancel
// 取消上一次请求
cancelRequest()
http.request({ url: url,headers: {'Cache-Control': 'no-store' },method: "post",data:{},cancelToken: new axios.CancelToken((c) => {
          // executor 函数接收一个 cancel 函数作为参数
          cancel = c;
        })})
        .then(async(res: any) => {
          
        })
        .catch(async(err: any) => {
          if (axios.isCancel(err)) {
            // 请求如果被取消
          } 
        });

 cancelRequest 取消请求方法

function cancelRequest () {
      if (typeof cancel === 'function') {
        cancel()
      }
   }

4.接口url添加事件戳

let url = '/xxx' + '?' + new Date().getTime();

5.可尝试使用tcp,udp,http2,http3,需要后端配合使用

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值