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

Vue3?Axios攔截器封裝成request文件的示例詳解

 更新時(shí)間:2023年04月21日 09:21:54   作者:城南城南  
這篇文章主要介紹了Vue3?Axios攔截器封裝成request文件,本文通過(guò)示例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下

可以將Axios攔截器封裝成一個(gè)單獨(dú)的request文件,以便在整個(gè)應(yīng)用程序中重復(fù)使用。

以下是一個(gè)示例,展示如何將Axios攔截器封裝成一個(gè)request文件:

1、創(chuàng)建一個(gè)名為request.js的新文件,并導(dǎo)入Axios:

import axios from 'axios';

2、創(chuàng)建一個(gè)名為request的函數(shù),并將其導(dǎo)出:

這將創(chuàng)建一個(gè)名為request的函數(shù),并將其設(shè)置為具有基本URL的新的Axios實(shí)例。要在封裝的Axios實(shí)例中添加超時(shí)設(shè)置,可以在創(chuàng)建Axios實(shí)例時(shí)傳遞timeout選項(xiàng)。

export const request = axios.create({
  baseURL: 'https://example.com/api',
  timeout: 5000, // 超時(shí)設(shè)置為5秒
});

3、在request函數(shù)中添加攔截器:

request.interceptors.request.use(function (config) {
  // 在發(fā)送請(qǐng)求之前做些什么
  return config;
}, function (error) {
  // 對(duì)請(qǐng)求錯(cuò)誤做些什么
  return Promise.reject(error);
});

request.interceptors.response.use(function (response) {
  // 對(duì)響應(yīng)數(shù)據(jù)做點(diǎn)什么
  return response;
}, function (error) {
  // 對(duì)響應(yīng)錯(cuò)誤做點(diǎn)什么
  return Promise.reject(error);
});

這將添加一個(gè)請(qǐng)求攔截器和一個(gè)響應(yīng)攔截器。可以在這些攔截器中執(zhí)行需要的操作,例如在請(qǐng)求發(fā)送之前添加身份驗(yàn)證標(biāo)頭或在響應(yīng)返回后檢查響應(yīng)數(shù)據(jù)是否有誤。

4、最后,導(dǎo)出request函數(shù):

export default request;

5、現(xiàn)在可以在應(yīng)用程序中使用request函數(shù)來(lái)執(zhí)行網(wǎng)絡(luò)請(qǐng)求,并且每個(gè)請(qǐng)求都將經(jīng)過(guò)預(yù)定義的攔截器。例如:

import request from './request';

request.get('/users')
  .then(function (response) {
    console.log(response);
  })
  .catch(function (error) {
    console.log(error);
  });

這將使用封裝的Axios實(shí)例發(fā)出GET請(qǐng)求,然后使用預(yù)定義的攔截器處理響應(yīng)

完整示例:

要在發(fā)送請(qǐng)求之前攜帶Token和Username,可以使用請(qǐng)求攔截器來(lái)為所有請(qǐng)求添加身份驗(yàn)證標(biāo)頭,

請(qǐng)求攔截器檢查localStorage中是否存在名為“token”和“username”的值,并將其添加為Authorization和Username標(biāo)頭。根據(jù)實(shí)際情況調(diào)整這些標(biāo)頭的名稱和值。

要對(duì)響應(yīng)數(shù)據(jù)進(jìn)行操作,使用響應(yīng)攔截器。在上面的示例中,響應(yīng)攔截器檢查響應(yīng)數(shù)據(jù)中的“status”屬性是否為“success”。如果不是,則將其視為錯(cuò)誤,并將其作為異常拋出。異常包含響應(yīng)對(duì)象,其中包含所有響應(yīng)信息,例如響應(yīng)頭、狀態(tài)碼和響應(yīng)體??梢愿鶕?jù)實(shí)際情況調(diào)整這些檢查和異常拋出的邏輯。

import axios from 'axios';

export const request = axios.create({
  baseURL: 'https://example.com/api',
  timeout: 5000, // 超時(shí)設(shè)置為5秒
});

request.interceptors.request.use(function (config) {
  // 在發(fā)送請(qǐng)求之前添加身份驗(yàn)證標(biāo)頭
  config.headers.Authorization = `Bearer ${localStorage.getItem('token')}`;
  config.headers.Username = localStorage.getItem('username');
  return config;
}, function (error) {
  // 對(duì)請(qǐng)求錯(cuò)誤做些什么
  return Promise.reject(error);
});
request.interceptors.response.use(function (response) {
  // 對(duì)響應(yīng)數(shù)據(jù)做些什么
  const responseData = response.data;
  if (responseData.status !== 'success') {
    const error = new Error(responseData.message || '請(qǐng)求失敗');
    error.response = response;
    throw error;
  }
  return responseData.data;
}, function (error) {
  // 對(duì)響應(yīng)錯(cuò)誤做些什么
  return Promise.reject(error);
});

到此這篇關(guān)于Vue3 Axios攔截器封裝成request文件的文章就介紹到這了,更多相關(guān)Vue3 Axios攔截器內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Vue3非遞歸渲染Tree組件的初步實(shí)現(xiàn)代碼

    Vue3非遞歸渲染Tree組件的初步實(shí)現(xiàn)代碼

    這篇文章主要介紹了Vue3非遞歸渲染Tree組件的初步實(shí)現(xiàn),文中通過(guò)代碼示例講解的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作有一定幫助,需要的朋友可以參考下
    2024-05-05
  • vue2響應(yīng)式的缺點(diǎn)影響

    vue2響應(yīng)式的缺點(diǎn)影響

    這篇文章主要介紹了vue2響應(yīng)式的缺點(diǎn)影響,文章圍繞主題展開(kāi)詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,需要的小伙伴可以參考一下
    2022-05-05
  • 淺析vue數(shù)據(jù)綁定

    淺析vue數(shù)據(jù)綁定

    本文主要介紹了vue數(shù)據(jù)綁定的相關(guān)知識(shí),具有一定的參考價(jià)值,下面跟著小編一起來(lái)看下吧
    2017-01-01
  • vue請(qǐng)求函數(shù)和路由的安裝使用過(guò)程

    vue請(qǐng)求函數(shù)和路由的安裝使用過(guò)程

    這篇文章主要介紹了vue請(qǐng)求函數(shù)和路由的安裝使用過(guò)程,本文給大家介紹的非常詳細(xì),感興趣的朋友跟隨小編一起看看吧
    2024-08-08
  • vue獲取DOM元素并設(shè)置屬性的兩種實(shí)現(xiàn)方法

    vue獲取DOM元素并設(shè)置屬性的兩種實(shí)現(xiàn)方法

    下面小編就為大家?guī)?lái)一篇vue獲取DOM元素并設(shè)置屬性的兩種實(shí)現(xiàn)方法。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2017-09-09
  • Vue通知提醒框(Notification)圖文詳解

    Vue通知提醒框(Notification)圖文詳解

    最近有個(gè)項(xiàng)目需求就是在客戶端的右上角要實(shí)時(shí)展示提醒消息,下面這篇文章主要給大家介紹了關(guān)于Vue通知提醒框(Notification)的相關(guān)資料,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2022-11-11
  • Vue 通過(guò)公共字段,拼接兩個(gè)對(duì)象數(shù)組的實(shí)例

    Vue 通過(guò)公共字段,拼接兩個(gè)對(duì)象數(shù)組的實(shí)例

    今天小編就為大家分享一篇Vue 通過(guò)公共字段,拼接兩個(gè)對(duì)象數(shù)組的實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2019-11-11
  • Vue2.0生命周期的理解

    Vue2.0生命周期的理解

    這篇文章主要為大家介紹了Vue2.0生命周期,思考與理解“el被新創(chuàng)建的vm.$el替換”這句話,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2018-08-08
  • 在Vue mounted方法中使用data變量詳解

    在Vue mounted方法中使用data變量詳解

    今天小編就為大家分享一篇在Vue mounted方法中使用data變量詳解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2019-11-11
  • vue實(shí)現(xiàn)計(jì)算器功能

    vue實(shí)現(xiàn)計(jì)算器功能

    這篇文章主要為大家詳細(xì)介紹了vue實(shí)現(xiàn)計(jì)算器功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-02-02

最新評(píng)論