亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

vue-resource 攔截器interceptors使用詳解

 更新時間:2021年01月18日 09:25:33   作者:LUOFather  
這篇文章主要介紹了vue-resource 攔截器interceptors使用詳解,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

前言

攔截器-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í)時個人單聊通訊

    這篇文章主要介紹了Vue在H5 項目中使用融云進(jìn)行實(shí)時個人單聊通訊,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-12-12
  • vue中多個倒計時實(shí)現(xiàn)代碼實(shí)例

    vue中多個倒計時實(shí)現(xiàn)代碼實(shí)例

    這篇文章主要介紹了vue中多個倒計時實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-03-03
  • VUE3之Non-Props屬性的具體使用

    VUE3之Non-Props屬性的具體使用

    本文主要介紹了VUE3之Non-Props屬性的具體使用,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-01-01
  • express+vue+mongodb+session 實(shí)現(xiàn)注冊登錄功能

    express+vue+mongodb+session 實(shí)現(xiàn)注冊登錄功能

    這篇文章主要介紹了express+vue+mongodb+session 實(shí)現(xiàn)注冊登錄,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價值,需要的朋友可以參考下
    2018-12-12
  • Vue實(shí)現(xiàn)彈出框點(diǎn)擊空白頁彈框消失效果

    Vue實(shí)現(xiàn)彈出框點(diǎn)擊空白頁彈框消失效果

    這篇文章主要介紹了VUE實(shí)現(xiàn)彈出框點(diǎn)擊空白頁彈框消失,實(shí)現(xiàn)方法可以在Vue中實(shí)現(xiàn)彈出框然后通過點(diǎn)擊空白頁面來讓彈窗隱藏,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),需要的朋友可以參考下
    2023-12-12
  • Vue2.0用戶權(quán)限控制解決方案的示例

    Vue2.0用戶權(quán)限控制解決方案的示例

    本篇文章主要介紹了Vue2.0用戶權(quán)限控制解決方案的示例,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-02-02
  • Vuex中g(shù)etters和actions的使用補(bǔ)充說明

    Vuex中g(shù)etters和actions的使用補(bǔ)充說明

    這篇文章主要介紹了在Vuex中關(guān)于getters和actions使用的補(bǔ)充作了簡要說明,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步
    2021-09-09
  • Vite創(chuàng)建Vue3項目及Vue3使用jsx詳解

    Vite創(chuàng)建Vue3項目及Vue3使用jsx詳解

    vite是新一代的前端構(gòu)建工具,下面這篇文章主要給大家介紹了關(guān)于Vite創(chuàng)建Vue3項目以及Vue3使用jsx的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2022-08-08
  • 詳解如何在vue中使用sass

    詳解如何在vue中使用sass

    本篇文章主要介紹了詳解如何在vue中使用sass,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-06-06
  • 項目nginx部署到非根目錄下vue配置方案

    項目nginx部署到非根目錄下vue配置方案

    這篇文章主要介紹了項目nginx部署到非根目錄下vue配置方案,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-12-12

最新評論