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

vue interceptor 使用教程實例詳解

 更新時間:2018年09月13日 10:20:01   作者:palmer_kai  
本文通過實例代碼給大家介紹了vue interceptor 使用,需要的朋友可以參考下

二次封裝axios,根據(jù)參數(shù)來實現(xiàn)多個請求多次攔截

1. 新建 axiosTool.js 文件,設置請求攔截和處理的邏輯

import Vue from 'vue'
import axios from 'axios'
//取消請求
let CancelToken = axios.CancelToken
//設置默認請求頭,如果不需要可以取消這一步
axios.defaults.headers = {
  'X-Requested-With': 'XMLHttpRequest'
}
// 請求超時的時間限制
axios.defaults.timeout = 20000
// 開始設置請求 發(fā)起的攔截處理
// config 代表發(fā)起請求的參數(shù)的實體
axios.interceptors.request.use(config => {
  // 得到參數(shù)中的 requestName 字段,用于決定下次發(fā)起請求,取消對應的 相同字段的請求
  // 如果沒有 requestName 就默認添加一個 不同的時間戳
  let requestName
  if(config.method === 'post'){
    if(config.data && config.data.requestName){
      requestName = config.data.requestName
    }else{
      requestName = new Date().getTime()
    }
  }else{
    if(config.params && config.params.requestName){
      requestName = config.params.requestName
    }else{
      requestName = new Date().getTime()
    }
  }
  // 判斷,如果這里拿到的參數(shù)中的 requestName 在上一次請求中已經存在,就取消上一次的請求
  if (requestName) {
    if (axios[requestName] && axios[requestName].cancel) {
      axios[requestName].cancel()
    }
    config.cancelToken = new CancelToken(c => {
      axios[requestName] = {}
      axios[requestName].cancel = c
    })
  }
  return config
}, error => {
  return Promise.reject(error)
})
// 請求到結果的攔截處理
axios.interceptors.response.use(config => {
  // 返回請求正確的結果
  return config
}, error => {
  // 錯誤的請求結果處理,這里的代碼根據(jù)后臺的狀態(tài)碼來決定錯誤的輸出信息
  if (error && error.response) {
    switch (error.response.status) {
      case 400:
        error.message = '錯誤請求'
        break
      case 401:
        error.message = '未授權,請重新登錄'
        break
      case 403:
        error.message = '拒絕訪問'
        break
      case 404:
        error.message = '請求錯誤,未找到該資源'
        break
      case 405:
        error.message = '請求方法未允許'
        break
      case 408:
        error.message = '請求超時'
        break
      case 500:
        error.message = '服務器端出錯'
        break
      case 501:
        error.message = '網絡未實現(xiàn)'
        break
      case 502:
        error.message = '網絡錯誤'
        break
      case 503:
        error.message = '服務不可用'
        break
      case 504:
        error.message = '網絡超時'
        break
      case 505:
        error.message = 'http版本不支持該請求'
        break
      default:
        error.message = `連接錯誤${error.response.status}`
    }
  } else {
    error.message = "連接到服務器失敗"
  }
  return Promise.reject(error.message)
})
// 將axios 的 post 方法,綁定到 vue 實例上面的 $post
Vue.prototype.$post = function (url, params) {
  return new Promise((resolve, reject) => {
    axios.post(url, params)
      .then(res => {
        resolve(res)
      }).catch(err => {
      reject(err)
    })
  })
}
// 將axios 的 get 方法,綁定到 vue 實例上面的 $get
Vue.prototype.$get = function (url, params) {
  return new Promise((resolve, reject) => {
    axios.get(url, {
      params: params
    }).then(res => {
      resolve(res) // 返回請求成功的數(shù)據(jù) data
    }).catch(err => {
      reject(err)
    })
  })
}
// 請求示例
// requestName 為多余的參數(shù) 作為請求的標識,下次發(fā)起相同的請求,就會自動取消上一次還沒有結束的請求
// 比如正常的請求參數(shù)只有一個 name: '123',但是這里我們需要額外再加上一個 requestName
/**
  this.$post(url, { name: '123', requestName: 'post_1' })
    .then(res => {
      console.log(`請求成功:${res}`)
    })
 */
export default axios

2. 再 main.js 中引入該文件

import { axios } from './static/js/axiosTool'

3. 在組件中直接使用即可

this.$post(this.url2, {
  name: "王",
  docType: "pson",
  requestName: 'name02'
}).then(res => {
  console.log(res)
})

this.$get(this.url, {
  name: "李",
  requestName: 'name01'
}).then(res => {
  console.log(res)
})

4. 效果如圖:

總結

以上所述是小編給大家介紹的vue interceptor 使用教程實例詳解,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網站的支持!

相關文章

  • Vue中使用裝飾器的方法詳解

    Vue中使用裝飾器的方法詳解

    裝飾器是一種與類相關的語法糖,用來包裝或者修改類或者類的方法的行為,其實裝飾器就是設計模式中裝飾者模式的一種實現(xiàn)方式,下面這篇文章主要給大家介紹了關于Vue中使用裝飾器的相關資料,需要的朋友可以參考下
    2022-01-01
  • Vue.js實現(xiàn)一個SPA登錄頁面的過程【推薦】

    Vue.js實現(xiàn)一個SPA登錄頁面的過程【推薦】

    本篇文章主要介紹了Vue.js寫一個SPA登錄頁面過程的相關知識,具有很好的參考價值。下面跟著小編一起來看下吧
    2017-04-04
  • Vue項目中使用mock.js的完整步驟

    Vue項目中使用mock.js的完整步驟

    這篇文章主要給大家介紹了關于在Vue項目中使用mock.js的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2021-01-01
  • vue 解決循環(huán)引用組件報錯的問題

    vue 解決循環(huán)引用組件報錯的問題

    今天小編就為大家分享一篇vue 解決循環(huán)引用組件報錯的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-09-09
  • vue關于data變量定義的問題

    vue關于data變量定義的問題

    這篇文章主要介紹了vue關于data變量定義的問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-03-03
  • Vue列表渲染的示例代碼

    Vue列表渲染的示例代碼

    這篇文章主要介紹了Vue列表渲染的示例代碼,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-11-11
  • 基于Vue2的獨立構建與運行時構建的差別(詳解)

    基于Vue2的獨立構建與運行時構建的差別(詳解)

    下面小編就為大家分享一篇基于Vue2的獨立構建與運行時構建的差別詳解,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2017-12-12
  • vue3組合式API實現(xiàn)todo列表效果

    vue3組合式API實現(xiàn)todo列表效果

    這篇文章主要介紹了vue3組合式API實現(xiàn)todo列表,下面用組合式?API的寫法,實現(xiàn)一個可新增、刪除的todo列表效果,需要的朋友可以參考下
    2024-08-08
  • 記錄一個Vue3簡易微信右滑刪除邏輯的思路實現(xiàn)

    記錄一個Vue3簡易微信右滑刪除邏輯的思路實現(xiàn)

    本文主要介紹了記錄一個Vue3簡易微信右滑邏輯的思路實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2022-07-07
  • vue項目中openlayers繪制行政區(qū)劃

    vue項目中openlayers繪制行政區(qū)劃

    這篇文章主要為大家詳細介紹了vue項目中openlayers繪制行政區(qū)劃,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-12-12

最新評論