欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Vue使用Axios請求攔截器的案例詳解

 更新時間:2024年12月05日 10:14:56   作者:景天科技苑  
在Vue項(xiàng)目中,Axios是一個非常流行的HTTP客戶端,用于發(fā)送請求和接收響應(yīng),Axios攔截器是Axios的一個強(qiáng)大功能,它允許你在請求發(fā)送之前和響應(yīng)返回之后對請求和響應(yīng)進(jìn)行處理和攔截,本文將結(jié)合實(shí)際案例,詳細(xì)介紹如何在Vue中使用Axios攔截器,需要的朋友可以參考下

Vue中Axios攔截器

在Vue項(xiàng)目中,Axios是一個非常流行的HTTP客戶端,用于發(fā)送請求和接收響應(yīng)。Axios攔截器是Axios的一個強(qiáng)大功能,它允許你在請求發(fā)送之前和響應(yīng)返回之后對請求和響應(yīng)進(jìn)行處理和攔截。通過攔截器,你可以添加請求頭、處理請求參數(shù)、處理錯誤等。本文將結(jié)合實(shí)際案例,詳細(xì)介紹如何在Vue中使用Axios攔截器。

一、安裝Axios

首先,你需要在Vue3項(xiàng)目中安裝Axios。你可以使用npm或yarn等包管理工具進(jìn)行安裝。

npm install axios

或者

yarn add axios

二、創(chuàng)建Axios實(shí)例

在Vue3項(xiàng)目中,通常會在項(xiàng)目的某個地方創(chuàng)建一個Axios實(shí)例,并對其進(jìn)行配置。你可以將Axios實(shí)例放在一個單獨(dú)的文件中,例如src/axios.js。

// src/axios.js
import axios from 'axios';

// 創(chuàng)建Axios實(shí)例
const axiosInstance = axios.create({
  baseURL: '// 你的基礎(chǔ)URL', // 設(shè)置請求的baseURL
  timeout: 5000, // 設(shè)置請求超時時間
});

// 導(dǎo)出Axios實(shí)例
export default axiosInstance;

在上面的代碼中,我們使用axios.create方法創(chuàng)建了一個Axios實(shí)例,并傳遞了一些配置選項(xiàng),例如baseURL和timeout。

三、設(shè)置請求攔截器

請求攔截器允許你在請求發(fā)送之前對請求進(jìn)行處理。你可以在Axios實(shí)例中使用interceptors.request.use方法來添加請求攔截器。

// src/axios.js
import axios from 'axios';

// 創(chuàng)建Axios實(shí)例
const axiosInstance = axios.create({
  baseURL: '// 你的基礎(chǔ)URL',
  timeout: 5000,
});

// 添加請求攔截器
axiosInstance.interceptors.request.use(
  (config) => {
    // 在發(fā)送請求之前做些什么
    // 例如,添加請求頭
    const token = localStorage.getItem('token');
    if (token) {
      config.headers['Authorization'] = `Bearer ${token}`;
    }
    
    // 處理請求參數(shù)
    // config.params = {
    //   ...config.params,
    //   key: 'value',
    // };

    return config;
  },
  (error) => {
    // 對請求錯誤做些什么
    return Promise.reject(error);
  }
);

// 導(dǎo)出Axios實(shí)例
export default axiosInstance;

在上面的代碼中,我們添加了一個請求攔截器。在攔截器中,我們檢查本地存儲中是否存在token,如果存在,則將其添加到請求頭中。你還可以對請求參數(shù)進(jìn)行處理,例如添加或修改參數(shù)。

四、設(shè)置響應(yīng)攔截器

響應(yīng)攔截器允許你在響應(yīng)返回之后對響應(yīng)進(jìn)行處理。你可以在Axios實(shí)例中使用interceptors.response.use方法來添加響應(yīng)攔截器。

// src/axios.js
import axios from 'axios';

// 創(chuàng)建Axios實(shí)例
const axiosInstance = axios.create({
  baseURL: '// 你的基礎(chǔ)URL',
  timeout: 5000,
});

// 添加請求攔截器(同上)

// 添加響應(yīng)攔截器
axiosInstance.interceptors.response.use(
  (response) => {
    // 對響應(yīng)數(shù)據(jù)做些什么
    // 例如,處理響應(yīng)數(shù)據(jù)格式
    // response.data = {
    //   ...response.data,
    //   key: 'value',
    // };

    return response;
  },
  (error) => {
    // 對響應(yīng)錯誤做些什么
    const { response } = error;
    if (response) {
      // 判斷錯誤狀態(tài)碼
      if (response.status === 400) {
        // 請求錯誤
      } else if (response.status === 401) {
        // 未授權(quán),請重新登錄
      } else if (response.status === 403) {
        // 拒絕訪問(403)
      }

      return Promise.reject(response.data);
    } else {
      console.error('網(wǎng)絡(luò)連接異常,請稍后再試!');
    }
  }
);

// 導(dǎo)出Axios實(shí)例
export default axiosInstance;

在上面的代碼中,我們添加了一個響應(yīng)攔截器。在攔截器中,我們可以對響應(yīng)數(shù)據(jù)進(jìn)行處理,例如修改數(shù)據(jù)格式。我們還可以根據(jù)響應(yīng)的狀態(tài)碼來處理不同的錯誤情況。

五、在Vue組件中使用Axios實(shí)例

現(xiàn)在,我們已經(jīng)在項(xiàng)目中創(chuàng)建了Axios實(shí)例,并添加了請求和響應(yīng)攔截器。接下來,我們可以在Vue組件中使用這個Axios實(shí)例來發(fā)送請求。

<!-- src/components/YourComponent.vue -->
<template>
  <div>數(shù)據(jù)展示</div>
</template>

<script>
import axiosInstance from '../axios';

export default {
  name: 'YourComponent',
  mounted() {
    axiosInstance.get('/your-endpoint')
      .then(data => {
        console.log(data);
      })
      .catch(error => {
        console.error('錯誤:', error);
      });
  },
};
</script>

在上面的代碼中,我們在Vue組件的mounted生命周期鉤子中使用了Axios實(shí)例來發(fā)送一個GET請求。請求成功后,我們將響應(yīng)數(shù)據(jù)打印到控制臺。如果請求失敗,我們將錯誤信息打印到控制臺。

六、封裝請求方法

為了更方便地在項(xiàng)目中發(fā)送請求,我們可以將常用的請求方法封裝起來。例如,我們可以封裝GET和POST請求方法。

// src/api/axios.js
import axios from 'axios';

// 創(chuàng)建Axios實(shí)例(同上)

// 封裝GET請求方法
export function getRequest(url, params = {}) {
  return axiosInstance.get(url, { params });
}

// 封裝POST請求方法
export function postRequest(url, data = {}) {
  return axiosInstance.post(url, data);
}

現(xiàn)在,我們可以在Vue組件中使用封裝好的請求方法來發(fā)送請求。

<!-- src/components/YourComponent.vue -->
<template>
  <div>數(shù)據(jù)展示</div>
</template>

<script>
import { getRequest, postRequest } from '../api/axios';

export default {
  name: 'YourComponent',
  mounted() {
    // 使用GET請求方法
    getRequest('/your-get-endpoint', { param1: 'value1' })
      .then(data => {
        console.log('GET請求響應(yīng):', data);
      })
      .catch(error => {
        console.error('GET請求錯誤:', error);
      });

    // 使用POST請求方法
    postRequest('/your-post-endpoint', { key: 'value' })
      .then(data => {
        console.log('POST請求響應(yīng):', data);
      })
      .catch(error => {
        console.error('POST請求錯誤:', error);
      });
  },
};
</script>

七、統(tǒng)一管理API接口

在項(xiàng)目中,我們可能會有很多API接口。為了方便管理和維護(hù),我們可以將這些接口統(tǒng)一管理起來。例如,我們可以在src/api目錄下創(chuàng)建一個api.js文件,并在其中定義所有的API接口。

// src/api/api.js
import { getRequest, postRequest } from './axios';

// 定義用戶相關(guān)API接口
export class UserApi {
  static async login(params) {
    return postRequest('/login', params);
  }

  static async register(params) {
    return postRequest('/register', params);
  }

  static async getUserInfo(params) {
    return getRequest('/userInfo', params);
  }
}

// 定義書籍相關(guān)API接口
export class BookApi {
  static async getBookList(params) {
    return getRequest('/bookList', params);
  }
}

現(xiàn)在,我們可以在Vue組件中使用統(tǒng)一管理好的API接口來發(fā)送請求。

<!-- src/components/YourComponent.vue -->
<template>
  <div>
    <button @click="handleLogin">登錄</button>
  </div>
</template>

<script>
import { UserApi } from '../api/api';

export default {
  name: 'YourComponent',
  methods: {
    async handleLogin() {
      const params = {
        username: 'admin',
        password: '123456',
      };
      try {
        const response = await UserApi.login(params);
        console.log('登錄成功:', response);
      } catch (error) {
        console.error('登錄失敗:', error);
      }
    },
  },
};
</script>

拓展:Vue配置axios響應(yīng)攔截器

一個項(xiàng)目會發(fā)送很多請求到后端,每個請求都有如下的響應(yīng)

不想每個請求都去判斷里面的status,那么可以使用axios的響應(yīng)攔截器,對服務(wù)端返回的一些相同點(diǎn)做統(tǒng)一的處理 

比如說如果有報錯,就統(tǒng)一彈出這么個錯誤信息

在src目錄下新建utils目錄里新建api.js(名字隨你自己)

原先彈出錯誤信息,可以直接只用

this.$message.error('請輸入正確格式')

但是現(xiàn)在是在js文件里,需要額外單獨(dú)引入

 配置axios響應(yīng)攔截器(其實(shí)也可以配置請求攔截器,就是在所有請求里添加什么什么什么,比如說統(tǒng)一添加請求頭)

這里先介紹響應(yīng)攔截器

import axios from 'axios'
import { Message } from 'element-ui';
import router from '../router'//導(dǎo)入文件夾,自動會去找里面的index.js
  
 
const instances = axios.create({
    baseURL: 'http://localhost',
  });
 
//響應(yīng)攔截器
instances.interceptors.response.use(success=>{//這個success指的是調(diào)用接口成功
    
    console.log('響應(yīng)攔截器,chenggong')
   
},error=>{//接口根本沒有調(diào)用到或者服務(wù)器掛了,各種原因
   
    console.log('響應(yīng)攔截器,shibai',error)
    Message.error({message:error})
});
 
// //可以在所有請求前添加前置路徑
// let base='';
 
// //封裝請求并導(dǎo)出
// export const postRequest=(url,params)=>{
//     return axios({
//         method:'post',
//         url:'${base}${url}',
//         data:params
//     })
// }
 
export default instances;

記得在main.js引入

引入的即為utils.api.js里

導(dǎo)出的

下面第一張圖用的是反引號,注意

到此這篇關(guān)于Vue使用Axios請求攔截器的案例詳解的文章就介紹到這了,更多相關(guān)Vue Axios請求攔截器內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • vue項(xiàng)目之webpack打包靜態(tài)資源路徑不準(zhǔn)確的問題

    vue項(xiàng)目之webpack打包靜態(tài)資源路徑不準(zhǔn)確的問題

    這篇文章主要介紹了vue項(xiàng)目之webpack打包靜態(tài)資源路徑不準(zhǔn)確的問題及解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-04-04
  • 詳解vue-flickity的fullScreen功能實(shí)現(xiàn)

    詳解vue-flickity的fullScreen功能實(shí)現(xiàn)

    這篇文章主要介紹了詳解vue-flickity的fullScreen功能實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-04-04
  • Vue導(dǎo)出頁面為PDF格式的實(shí)現(xiàn)思路

    Vue導(dǎo)出頁面為PDF格式的實(shí)現(xiàn)思路

    這篇文章主要介紹了Vue導(dǎo)出頁面為PDF格式的實(shí)現(xiàn)思路,其實(shí)思路也很簡單,就是將頁面轉(zhuǎn)換成圖片格式.然后通過圖片的base64碼.生成PDF..感興趣的朋友跟隨腳本之家小編一起看看吧
    2018-07-07
  • Vue利用AJAX請求獲取XML文件數(shù)據(jù)的操作方法

    Vue利用AJAX請求獲取XML文件數(shù)據(jù)的操作方法

    在現(xiàn)代Web開發(fā)中,從前端框架到后端API的交互是必不可少的一部分,Vue.js作為一個輕量級且功能強(qiáng)大的前端框架,支持多種方式與服務(wù)器通信,從而獲取或發(fā)送數(shù)據(jù),本文將詳細(xì)介紹如何在Vue.js項(xiàng)目中使用AJAX請求來獲取XML格式的數(shù)據(jù),需要的朋友可以參考下
    2024-09-09
  • SpringBoot+Vue項(xiàng)目線上買菜系統(tǒng)源碼展示

    SpringBoot+Vue項(xiàng)目線上買菜系統(tǒng)源碼展示

    本線上買菜系統(tǒng)采用的數(shù)據(jù)庫是Mysql,使用springboot框架開發(fā)。在設(shè)計過程中,充分保證了系統(tǒng)代碼的良好可讀性、實(shí)用性、易擴(kuò)展性、通用性、便于后期維護(hù)、操作方便以及頁面簡潔等特點(diǎn),需要的朋友可以參考下
    2022-08-08
  • 使用Vue編寫一個日期選擇器

    使用Vue編寫一個日期選擇器

    這篇文章主要為大家詳細(xì)介紹了如何使用Vue編寫一個簡單的日期選擇器,文中的示例代碼講解詳細(xì),具有一定的借鑒價值,感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下
    2023-12-12
  • vue3.2?reactive函數(shù)問題小結(jié)

    vue3.2?reactive函數(shù)問題小結(jié)

    reactive用來包裝一個對象,使其每個對象屬性都具有響應(yīng)性(也就是深層次響應(yīng)式),這篇文章主要介紹了vue3.2?reactive函數(shù)注意點(diǎn)及問題小結(jié),需要的朋友可以參考下
    2022-12-12
  • Vue ElementUi同時校驗(yàn)多個表單(巧用new promise)

    Vue ElementUi同時校驗(yàn)多個表單(巧用new promise)

    這篇文章主要介紹了巧用new promise實(shí)現(xiàn)Vue ElementUi同時校驗(yàn)多個表單功能,實(shí)現(xiàn)的方法有很多種,本文給大家?guī)淼氖且环N比較完美的方案,需要的朋友可以參考下
    2018-06-06
  • vue3?邏輯復(fù)用的實(shí)現(xiàn)示例

    vue3?邏輯復(fù)用的實(shí)現(xiàn)示例

    在項(xiàng)目開發(fā)中,有兩個功能特別類似,如果單獨(dú)實(shí)現(xiàn),會有很多重復(fù)的代碼,這時候就會用到邏輯復(fù)用,本文主要介紹了vue3?邏輯復(fù)用的實(shí)現(xiàn)示例,具有一定的參考價值,感興趣的可以了解一下
    2024-02-02
  • ant-design-vue按鈕樣式擴(kuò)展方法詳解

    ant-design-vue按鈕樣式擴(kuò)展方法詳解

    這篇文章主要為大家介紹了ant-design-vue按鈕樣式擴(kuò)展方法詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-06-06

最新評論