您好,登錄后才能下訂單哦!
這篇文章主要介紹“vue的Vue.http.interceptors.push攔截器怎么使用”,在日常操作中,相信很多人在vue的Vue.http.interceptors.push攔截器怎么使用問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”vue的Vue.http.interceptors.push攔截器怎么使用”的疑惑有所幫助!接下來,請跟著小編一起來學習吧!
代碼如下:
import store from './vuex/store' // 全局錯誤處理,全局loading import { setLoading, setTip } from './vuex/actions/doc_actions' export default function (request, next) { if (request.tip !== false) { setLoading(store, true) } next((res) => { setLoading(store, false) let data = JSON.parse(res.data) if (res.status === 0) { setTip(store, { text: '網(wǎng)絡(luò)不給力,請稍后再試' }) } if (!data.success) { setTip(store, { text: data.error_msg }) } }) }
這是一個全局的攔截器。于是搜索vue攔截器的用法,下面這一篇寫的不錯:
vue-resource 攔截器使用詳解
在vue項目使用vue-resource的過程中,臨時增加了一個需求,需要在任何一個頁面任何一次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進行接收。那么我們可以在這個攔截器里邊添加對響應(yīng)狀態(tài)碼的判斷,來決定是跳轉(zhuǎn)到登錄頁面還是留在當前頁面繼續(xù)獲取數(shù)據(jù)。攔截器詳細介紹》》
下邊代碼添加在main.js中
Vue.http.interceptors.push((request, next) => { console.log(this)//此處this為請求所在頁面的Vue實例 // modify request request.method = 'POST';//在請求之前可以進行一些預(yù)處理和配置 // continue to next interceptor next((response) => {//在響應(yīng)之后傳給then之前對response進行修改和邏輯判斷。對于token時候已過期的判斷,就添加在此處,頁面中任何一次http請求都會先調(diào)用此處方法 response.body = '...'; return response; }); });
Vue是一款友好的、多用途且高性能的JavaScript框架,使用vue可以創(chuàng)建可維護性和可測試性更強的代碼庫,Vue允許可以將一個網(wǎng)頁分割成可復用的組件,每個組件都包含屬于自己的HTML、CSS、JavaScript,以用來渲染網(wǎng)頁中相應(yīng)的地方,所以越來越多的前端開發(fā)者使用vue。
到此,關(guān)于“vue的Vue.http.interceptors.push攔截器怎么使用”的學習就結(jié)束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續(xù)學習更多相關(guān)知識,請繼續(xù)關(guān)注億速云網(wǎng)站,小編會繼續(xù)努力為大家?guī)砀鄬嵱玫奈恼拢?/p>
免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。