vue-resource 攔截器interceptors使用詳解
前言
攔截器-interceptor
在現(xiàn)代的一些前端框架上,攔截器基本上是很基礎(chǔ)但很重要的一環(huán),比如Angular原生就支持?jǐn)r截器配置,VUE的Axios模塊也給我們提供了攔截器配置,那么攔截器到底是什么,它有什么用?
攔截器能幫助我們解決的
- 添加統(tǒng)一的request的參數(shù)
- 比如header中加入X-Requested-With,比如客戶端需要實(shí)現(xiàn)sign和token的驗證機(jī)制,比如你可以寫$http.get(‘/files', params),攔截器幫你拼接成 http://www.xxxx.com/1/files 這樣的請求地址
- 處理統(tǒng)一的responseError
- 比如重連機(jī)制,拿到error.code錯誤碼重連,比如token過期,重新拿到token再次send request
- 比如統(tǒng)一報錯信息,給所有返回的404來個提示也會很酷
在vue項目使用vue-resource實(shí)現(xiàn)異步加載的過程中,需要在任何一個頁面任何一次http請求過程中,增加對token過期的判斷,如果token已過期,需要跳轉(zhuǎn)至登錄頁面。如果要在每個頁面中的http請求操作中添加一次判斷,那將會是一個非常大的修改工作量。那么vue-resource是否存在一個對于任何一次請求響應(yīng)捕獲的的公共回調(diào)函數(shù)呢?答案是有的!
vue-resource的interceptors攔截器的作用正是解決此需求的妙方。在每次http的請求響應(yīng)之后,如果設(shè)置了攔截器,會優(yōu)先執(zhí)行攔截器函數(shù),獲取響應(yīng)體,然后才會決定是否把response返回給then進(jìn)行接收。那么我們可以在這個攔截器里邊添加對響應(yīng)狀態(tài)碼的判斷,來決定是跳轉(zhuǎn)到登錄頁面還是留在當(dāng)前頁面繼續(xù)獲取數(shù)據(jù)。
安裝與引用
NPM: npm install vue-resource --save-dev
/*引入Vue框架*/ import Vue from 'vue' /*引入資源請求插件*/ import VueResource from 'vue-resource' /*使用VueResource插件*/ Vue.use(VueResource)
下邊代碼添加在main.js中
Vue.http.interceptors.push((request, next) => { console.log(this)//此處this為請求所在頁面的Vue實(shí)例 // modify request request.method = 'POST';//在請求之前可以進(jìn)行一些預(yù)處理和配置 // continue to next interceptor next((response) => {//在響應(yīng)之后傳給then之前對response進(jìn)行修改和邏輯判斷。對于token時候已過期的判斷,就添加在此處,頁面中任何一次http請求都會先調(diào)用此處方法 response.body = '...'; return response; }); });
攔截器實(shí)例
(1)為請求添加loading效果
通過inteceptor,我們可以為所有的請求處理加一個loading:請求發(fā)送前顯示loading,接收響應(yīng)后隱藏loading。
具體步驟如下:
//1、添加一個loading組件 <template id='loading-template'> <div class='loading-overlay'></div> </template> //2、將loading組件作為另外一個Vue實(shí)例的子組件 var help = new Vue({ el: '#help', data: { showLoading: false }, components: { 'loading': { template: '#loading-template', } } }) //3、將該Vue實(shí)例掛載到某個HTML元素 <div id='help'> <loading v-show='showLoading'></loading> </div> //4、添加inteceptor Vue.http.interceptors.push((request, next) => { loading.show = true; next((response) => { loading.show = false; return response; }); });
但是,當(dāng)用戶在畫面上停留時間太久時,視圖數(shù)據(jù)可能已經(jīng)不是最新的了,這時如果用戶刪除或修改某一條數(shù)據(jù),如果這條數(shù)據(jù)已經(jīng)被其他用戶刪除了,服務(wù)器會反饋一個404的錯誤,但由于我們的put和delete請求沒有處理errorCallback,所以用戶是不知道他的操作是成功還是失敗了。這個問題,同樣也可以通過inteceptor解決。
(2)為請求添加共同的錯誤處理方法
//1、繼續(xù)沿用上面的loading組件,在#help元素下加一個對話框 <div id='help'> <loading v-show='showLoading' ></loading> <modal-dialog :show='showDialog'> <header class='dialog-header' slot='header'> <h3 class='dialog-title'>Server Error</h3> </header> <div class='dialog-body' slot='body'> <p class='error'>Oops,server has got some errors, error code: {{errorCode}}.</p> </div> </modal-dialog> </div> //2、給help實(shí)例的data選項添加兩個屬性 var help = new Vue({ el: '#help', data: { showLoading: false, showDialog: false, errorCode: '' }, components: { 'loading': { template: '#loading-template', } } }) //3、修改inteceptor Vue.http.interceptors.push((request, next) => { help.showLoading = true; next((response) => { if(!response.ok){ help.errorCode = response.status; help.showDialog = true; } help.showLoading = false; return response; }); });
到此這篇關(guān)于vue-resource 攔截器interceptors使用詳解的文章就介紹到這了,更多相關(guān)vue-resource攔截器內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Vue在H5 項目中使用融云進(jìn)行實(shí)時個人單聊通訊
這篇文章主要介紹了Vue在H5 項目中使用融云進(jìn)行實(shí)時個人單聊通訊,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-12-12vue中多個倒計時實(shí)現(xiàn)代碼實(shí)例
這篇文章主要介紹了vue中多個倒計時實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-03-03express+vue+mongodb+session 實(shí)現(xiàn)注冊登錄功能
這篇文章主要介紹了express+vue+mongodb+session 實(shí)現(xiàn)注冊登錄,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價值,需要的朋友可以參考下2018-12-12Vue實(shí)現(xiàn)彈出框點(diǎn)擊空白頁彈框消失效果
這篇文章主要介紹了VUE實(shí)現(xiàn)彈出框點(diǎn)擊空白頁彈框消失,實(shí)現(xiàn)方法可以在Vue中實(shí)現(xiàn)彈出框然后通過點(diǎn)擊空白頁面來讓彈窗隱藏,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),需要的朋友可以參考下2023-12-12Vuex中g(shù)etters和actions的使用補(bǔ)充說明
這篇文章主要介紹了在Vuex中關(guān)于getters和actions使用的補(bǔ)充作了簡要說明,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步2021-09-09Vite創(chuàng)建Vue3項目及Vue3使用jsx詳解
vite是新一代的前端構(gòu)建工具,下面這篇文章主要給大家介紹了關(guān)于Vite創(chuàng)建Vue3項目以及Vue3使用jsx的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-08-08