如題,項(xiàng)目是vue-cli單頁(yè)面應(yīng)用,所以即使在跳轉(zhuǎn)路由,上一個(gè)頁(yè)面的請(qǐng)求也不會(huì)停止,這樣會(huì)產(chǎn)生一系列問(wèn)題。。。
在axios的官方文檔發(fā)現(xiàn)了取消請(qǐng)求的方法,于是我就動(dòng)手在我封裝的axios里面試了試,沒(méi)有成功,求指教
如圖:我在base.js里創(chuàng)建了axios的實(shí)例,并且配置了canceltoken
問(wèn):我現(xiàn)在想要在每次跳轉(zhuǎn)路由前調(diào)用cancel方法應(yīng)該怎么弄(我的beforeEach在main.js中)
beforeRouteLeave。
將所有的當(dāng)前請(qǐng)求組織一個(gè)list放在this里,然后在離開(kāi)路由的時(shí)候cancel即可
要取消請(qǐng)求的話,肯定要記錄你當(dāng)前的所有請(qǐng)求
// 添加請(qǐng)求攔截器
axios.interceptors.request.use(
config => {
// 記錄該條請(qǐng)求,我用的是url,你可以用其他
const url = config.url;
// 把cancel放在axios.list[url]下面
config.cancelToken = new axios.CancelToken(cancel => axios.list[url] = { cancel });
return config;
},
error => Promise.reject(error)
);
//然后可以在其他地方,遍歷axios.list,調(diào)用list里面的cancel就可以取消當(dāng)前所有請(qǐng)求
for(let key in axios.list){
axios.list[key].cancel();
//順手刪除
delete axios.list[key];
}難點(diǎn)就是怎么在組件里拿到cancel,
那就利用函數(shù)的形參是對(duì)象的話,函數(shù)內(nèi)部改變對(duì)象屬性會(huì)影響到實(shí)參,
這樣的話 在base里面改變對(duì)象之后,組件調(diào)用api時(shí)傳過(guò)去的對(duì)象也會(huì)被改變,
我有做過(guò)類似的,但是我看你封裝的axios跟我的不大一樣,而且也看不出你是怎么使用instance的,我就把我的思路告訴你把
頁(yè)面組件調(diào)用的地方:
this.$api.getInfo(params, this.cancel) // cancel = {}
接口:
getInfo(params, cancel) {
return base(params, cancel)
}
base:
拿到cancel這個(gè)對(duì)象,然后給這個(gè)空對(duì)象添加一個(gè)屬性cancel,值是可終止請(qǐng)求的函數(shù)體
省略了很多,只有個(gè)大致思路
export const base = (params, cancel,.....) => {
let config = {....}
config.cancelToken = new CancelToken(function executor(c) {
cancel.cancel = c;
})
return axios(config)
}北大青鳥(niǎo)APTECH成立于1999年。依托北京大學(xué)優(yōu)質(zhì)雄厚的教育資源和背景,秉承“教育改變生活”的發(fā)展理念,致力于培養(yǎng)中國(guó)IT技能型緊缺人才,是大數(shù)據(jù)專業(yè)的國(guó)家
達(dá)內(nèi)教育集團(tuán)成立于2002年,是一家由留學(xué)海歸創(chuàng)辦的高端職業(yè)教育培訓(xùn)機(jī)構(gòu),是中國(guó)一站式人才培養(yǎng)平臺(tái)、一站式人才輸送平臺(tái)。2014年4月3日在美國(guó)成功上市,融資1
北大課工場(chǎng)是北京大學(xué)校辦產(chǎn)業(yè)為響應(yīng)國(guó)家深化產(chǎn)教融合/校企合作的政策,積極推進(jìn)“中國(guó)制造2025”,實(shí)現(xiàn)中華民族偉大復(fù)興的升級(jí)產(chǎn)業(yè)鏈。利用北京大學(xué)優(yōu)質(zhì)教育資源及背
博為峰,中國(guó)職業(yè)人才培訓(xùn)領(lǐng)域的先行者
曾工作于聯(lián)想擔(dān)任系統(tǒng)開(kāi)發(fā)工程師,曾在博彥科技股份有限公司擔(dān)任項(xiàng)目經(jīng)理從事移動(dòng)互聯(lián)網(wǎng)管理及研發(fā)工作,曾創(chuàng)辦藍(lán)懿科技有限責(zé)任公司從事總經(jīng)理職務(wù)負(fù)責(zé)iOS教學(xué)及管理工作。
浪潮集團(tuán)項(xiàng)目經(jīng)理。精通Java與.NET 技術(shù), 熟練的跨平臺(tái)面向?qū)ο箝_(kāi)發(fā)經(jīng)驗(yàn),技術(shù)功底深厚。 授課風(fēng)格 授課風(fēng)格清新自然、條理清晰、主次分明、重點(diǎn)難點(diǎn)突出、引人入勝。
精通HTML5和CSS3;Javascript及主流js庫(kù),具有快速界面開(kāi)發(fā)的能力,對(duì)瀏覽器兼容性、前端性能優(yōu)化等有深入理解。精通網(wǎng)頁(yè)制作和網(wǎng)頁(yè)游戲開(kāi)發(fā)。
具有10 年的Java 企業(yè)應(yīng)用開(kāi)發(fā)經(jīng)驗(yàn)。曾經(jīng)歷任德國(guó)Software AG 技術(shù)顧問(wèn),美國(guó)Dachieve 系統(tǒng)架構(gòu)師,美國(guó)AngelEngineers Inc. 系統(tǒng)架構(gòu)師。