vue页面跳转取消上一个页面请求

本文介绍了如何在Vue应用中使用Vuex存储axios的取消函数数组,通过axios请求拦截器设置cancelToken,并在路由守卫中清空上一页面请求。详细讲解了state、mutations的配置和axios拦截器的实现,确保了跨页面请求的优雅管理。

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

核心:

1:vuex以数组的形式存放取消函数;
2:axios请求拦截中设置cancelToken;
3:页面跳转路由守卫取消上一个页面所有的请求。

vuex中

在vuex中设置一个存放取消函数的数组,还有一个添加数组元素的方法和清空数组的方法:

这里放到了自定义的home模块:

export default {
/**
* 定义命名空间,防止多个模块同名共享,使用时需要带上命名空间
*/
    namespaced: true,
    state: {
        _axiosPromiseArr:[],
    },
    mutations: {
        add_AxiosPromiseArr(state, item) {
            console.log("添加_axiosPromiseArr");
            state._axiosPromiseArr.push(item)
        },
        clear_AxiosPromiseArr(state) {
            console.log("_axiosPromiseArr情空");
            state._axiosPromiseArr = []
        },
    },
}

axios的拦截:

import axios from 'axios'
import store from '../../store/index'

let Ajax = axios.create({
    baseURL: "http://127.0.0.1:3003/",
    timeout: 50000
})
Ajax.interceptors.request.use(async config => {

  //重点:重点:重点:重点:重点:重点:重点:重点:重点:
    config.cancelToken = new axios.CancelToken(cancel => {
        store.commit('home/add_AxiosPromiseArr', { cancel })
    })
  //重点:重点:重点:重点:重点:重点:重点:重点:重点:


    return config;
}, error => {
    return Promise.reject(error);
});
Ajax.interceptors.response.use(response => {
    return response.data;
}, error => {
    return Promise.reject(error);
});
const getTIP = (url, params) => {
    Ajax.defaults.headers['token'] = localStorage.getItem('token')
    return new Promise((relove, reject) => {
        Ajax.get(url, { params, responseType: "arraybuffer", headers: { responseType: 'arraybuffer' } }).then(res => relove(res)).catch(err => reject(err))
    })
}
export default {
     getTIP
}

路由守卫:

router.js

router.beforeEach((t, f, n) => {
    store.state.home._axiosPromiseArr.forEach((ele, index) => {
        ele.cancel("跳转页面,结束请求") // 路由跳转之前,清空(终止)上一个页面正在请求的内容
    })
    store.commit('home/clear_AxiosPromiseArr')
    if (t.path.includes('login') || t.path.includes('zjq')) {
        n()
    }
    if (!localStorage.getItem('token')) {
        n('/login')
    } else {
        n()
    }
})
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

六卿

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值