在vue里取消axios的请求

本文探讨了在Vue应用中遇到的公共组件根据不同tab切换数据渲染问题。当快速切换tab时,可能会导致请求交错,解决方案是在切换tab前取消当前请求。通过使用axios的CancelToken,可以在组件内创建并管理请求的取消源,确保每个tab对应的数据加载正确。同时,文章也提出了管理多个请求取消的方法,以保证在需要时能中断所有请求。
摘要由CSDN通过智能技术生成

一、搬砖遇到的问题
在搬砖的时候,遇到了一个问题,公共组件A是需要传一个数组进去渲染,在tab1下面是需要从接口请求返回的数据渲染,在tab2下则是读取配置文件的内容。在网络比较慢的情况下,快速从tab2切换到tab1再切换回tab2的时候,会先渲染tab2从配置文件中读取数组,然后再渲染成tab1请求回来的数据列表,然后就不再变化了。

二、如此就需要在切换到tab2之前,把tab1的请求给取消了。

三、具体的方法:

取消单个请求的方法,可以像下面的方法,把CancelToken的source放在data里,初始化组件的时候,可以赋值,要取消请求的时候,就直接source.cancel就可以了。

import axios from 'axios';

export default {
	data: () => ({
		source: null,
	}),
	mounted() {
		this.source = axios.CancelToken.source();
	},
	methods: {
		async getList() {
			const { data, code } = await axios.get(
				'/XXXX/XXXX/',
				{ 
					cancelToken: this.source.token,
				}
			)
		},
		changeTab() {
			this.source.cancel('change tab');
		},
	}
}

取消多个请求,可以把CancelToken取出来,每个请求都重新new一个cancelToken,并把每个cancelToken放到 一个公共数组里,在需要所有的请求都中断时,就遍历数组,每个都执行一遍。在请求完成的时候,要在数组中去掉对应的cancelToken,在页面或者数组卸载的时候,记得清空数组。

Vue项目中,我们通常会使用axios来发送请求。为了方便管理和维护代码,我们可以将axios请求进行统一封装。 首先,我们需要在项目中安装axios: ``` npm install axios --save ``` 然后,我们可以在src目录下新建一个api目录,用来存放所有的接口请求。在api目录下,我们可以新建一个request.js文件,用来封装axios请求: ``` import axios from 'axios'; // 创建axios实例 const service = axios.create({ baseURL: process.env.BASE_API, // api的base_url timeout: 5000 // 请求超时时间 }); // request拦截器 service.interceptors.request.use(config => { // 在请求发送之前做一些处理 return config; }, error => { // 处理请求错误 console.log(error); Promise.reject(error); }) // respone拦截器 service.interceptors.response.use( response => { // 在接收响应做一些处理,例如统一的错误处理 return response.data; }, error => { console.log('err' + error);// for debug return Promise.reject(error); } ) export default service; ``` 这我们创建了一个axios实例,并进行了一些配置,例如设置请求超时时间、拦截请求和响应等。并且将其导出,其他地方可以直接引用该实例进行请求。 接下来,我们可以在api目录下新建一个模块,例如user.js,用来存放用户相关的接口请求。在user.js中,我们可以这样写: ``` import request from '@/api/request'; export function login(username, password) { return request({ url: '/user/login', method: 'post', data: { username, password } }) } export function getInfo(token) { return request({ url: '/user/info', method: 'get', params: { token } }) } ``` 这我们引入了之前封装的axios实例,然后对外导出两个方法login和getInfo,分别用来请求登录和获取用户信息的接口。 最后,我们可以在Vue组件中使用这些接口,例如: ``` import { login, getInfo } from '@/api/user'; export default { name: 'Login', methods: { handleLogin() { login(this.username, this.password).then(response => { // 处理登录成功的逻辑 getInfo(response.token).then(info => { // 处理获取用户信息成功的逻辑 }) }) } } } ``` 这我们引入了之前定义的login和getInfo方法,并在handleLogin方法中调用它们。需要注意的是,我们在处理登录成功后,还调用了getInfo方法来获取用户信息。这我们可以看到,我们可以将多个请求串联起来进行处理。 在实际开发中,我们经常会遇到重复请求的问题,例如多次点击提交按钮或者页面切换时进行数据加载等。为了避免重复请求,我们可以对axios进行进一步封装,例如: ``` import axios from 'axios'; // 定义一个空的数组,用来存储每个请求取消函数和标识 const pending = []; const CancelToken = axios.CancelToken; const removePending = (config) => { for (let i = 0; i < pending.length; i++) { if (pending[i].url === config.url + '&' + config.method) { pending[i].cancel(); // 取消重复请求 pending.splice(i, 1); // 删除已经取消请求记录 } } } // 创建axios实例 const service = axios.create({ baseURL: process.env.BASE_API, // api的base_url timeout: 5000 // 请求超时时间 }); // request拦截器 service.interceptors.request.use(config => { // 在请求发送之前做一些处理 removePending(config); config.cancelToken = new CancelToken((c) => { pending.push({ url: config.url + '&' + config.method, cancel: c }); }); return config; }, error => { // 处理请求错误 console.log(error); Promise.reject(error); }) // respone拦截器 service.interceptors.response.use( response => { // 在接收响应做一些处理,例如统一的错误处理 removePending(response.config); return response.data; }, error => { console.log('err' + error);// for debug return Promise.reject(error); } ) export default service; ``` 这我们定义了一个pending数组,用来存储每个请求取消函数和标识。在每次请求发送之前,我们会先调用removePending函数,用来取消重复请求。在每次请求完成之后,我们会再次调用removePending函数,用来删除已经取消请求记录。这样就可以避免重复请求的问题了。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值