vue路由跳转取消上个页面的请求
第一步:
axios请求头设置
import axios from 'axios'import { store } from './store' // 引入vuex
axios.interceptors.request.use(
config => {
config.cancelToken = new axios.CancelToken(function (cancel) {
store.commit('pushToken', {cancelToken: cancel})
})
return config
}
)
第二步:
利用vuex,新建一个store.js,将取消方法cancel放到数组中,然后在路由守卫中把数组中存有的cancel方法都执行
import Vue from 'vue'import Vuex from 'vuex'
Vue.use(Vuex)
export const store = new Vuex.Store({
state: {
cancelTokenArr: [] // 取消请求token数组
},
mutations: {
pushToken (state, payload) {
state.cancelTokenArr.push(payload.cancelToken)
},
clearToken (state) {
state.cancelTokenArr.forEach(item => {
item('路由跳转取消请求')
})
state.cancelTokenArr = []
}
}
})
第三步:
监听路由
router.beforeEach(function (to, from, next) { store.commit('clearToken') // 取消请求
next()
})
https://my.oschina.net/u/4309525/blog/3281330
http://www.axios-js.com/zh-cn/docs/#取消
以上是 vue路由跳转取消上个页面的请求 的全部内容, 来源链接: utcz.com/z/375554.html