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

vue3中封裝axios請(qǐng)求最新實(shí)現(xiàn)步驟

 更新時(shí)間:2024年04月27日 14:25:14   作者:爾嶸  
這篇文章主要給大家介紹了關(guān)于vue3中封裝axios請(qǐng)求的最新實(shí)現(xiàn)步驟,在Vue 3中可以通過(guò)封裝axios來(lái)實(shí)現(xiàn)接口的統(tǒng)一管理和調(diào)用,文中通過(guò)代碼介紹的非常詳細(xì),需要的朋友可以參考下

在 Vue3 中,可以使用 axios 庫(kù)進(jìn)行網(wǎng)絡(luò)請(qǐng)求,并將其封裝到一個(gè)自定義的函數(shù)中以便全局使用。具體實(shí)現(xiàn)步驟如下:

1.安裝 Axios:可以通過(guò) npm 或 yarn 安裝 axios 庫(kù)。

npm install axios
# 或者
yarn add axios

2.創(chuàng)建一個(gè) axios 實(shí)例并設(shè)置默認(rèn)配置項(xiàng)和攔截器,該文件取名叫request.js

import axios from 'axios'
const service = axios.create({
  baseURL: process.env.VUE_APP_BASE_API,
  timeout: 5000
})

// request 攔截器
service.interceptors.request.use(
  config => {
    // 在這里可以設(shè)置請(qǐng)求頭、請(qǐng)求參數(shù)等return config
  },
  error => {
    console.log(error)
    return Promise.reject(error)
  }
)

// response 攔截器
service.interceptors.response.use(
  response => {
    // 在這里處理返回?cái)?shù)據(jù)const { data } = response
    if (data.code !== 200) {
      console.error('Error:', data.message)
      return Promise.reject(newError(data.message || 'Error'))
    } else {
      return data
    }
  },
  error => {
    console.log(error)
    return Promise.reject(error)
  }
)

// 封裝具體的請(qǐng)求方法: 四種請(qǐng)求類型不和下面的3和4標(biāo)題內(nèi)容放在一起
export const get = (url, params) => {
  return service .get(url, { params });
};

export const post = (url, data) => {
  return service .post(url, data);
};

export const put = (url, data) => {
  return service .put(url, data);
};

export const delete= (url, data) => {
  return service .delete(url, data);
};

export default service

在上述代碼中,我們創(chuàng)建了一個(gè)名為 service 的 axios 實(shí)例,并設(shè)置了一些默認(rèn)的配置項(xiàng)和攔截器。其中,request 攔截器用于請(qǐng)求發(fā)送前對(duì)請(qǐng)求做一些處理,例如設(shè)置請(qǐng)求頭、請(qǐng)求參數(shù)等;response 攔截器用于對(duì)返回?cái)?shù)據(jù)進(jìn)行處理,例如根據(jù)接口返回的狀態(tài)碼判斷請(qǐng)求是否成功等。

3.將 axios 封裝到一個(gè)函數(shù)中,api.js

import service from '@/utils/request'
export function request(config) {
  return service(config)
}

在上述代碼中,我們將 axios 封裝到一個(gè)名為 request 的函數(shù)中,并導(dǎo)出該函數(shù),以便在其他地方可以直接調(diào)用。

4.在代碼中使用封裝好的 axios 請(qǐng)求

import { request } from '@/api'
request({
  url: '/user',
  method: 'get'
}).then(response => {
  console.log(response)
})

5.結(jié)合request.js中四種請(qǐng)求,代替上面3和4標(biāo)題

import { get, post,put, delete } from '@/utils/request';

// 發(fā)送GET請(qǐng)求的示例
get('/users', { id: 1 })
  .then((response) => {
    // 處理響應(yīng)數(shù)據(jù)
    console.log(response);
  })
  .catch((error) => {
    // 處理請(qǐng)求錯(cuò)誤
    console.error(error);
  });

// 發(fā)送POST請(qǐng)求的示例
post('/users', { name: 'John', age: 25 })
  .then((response) => {
    // 處理響應(yīng)數(shù)據(jù)
    console.log(response);
  })
  .catch((error) => {
    // 處理請(qǐng)求錯(cuò)誤
    console.error(error);
  });

在上述代碼中,我們引入封裝好的 request 函數(shù),并通過(guò)傳遞一個(gè)包含請(qǐng)求參數(shù)的配置對(duì)象來(lái)發(fā)起網(wǎng)絡(luò)請(qǐng)求。

總結(jié)

需要注意的是,在實(shí)際應(yīng)用中,我們可能還需要根據(jù)業(yè)務(wù)需求進(jìn)一步封裝不同類型的請(qǐng)求,例如 GET 請(qǐng)求、POST 請(qǐng)求、PUT請(qǐng)求、DELETE等,以及處理請(qǐng)求錯(cuò)誤等情況。

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

相關(guān)文章

  • Vue3中結(jié)合ElementPlus實(shí)現(xiàn)彈窗的封裝方式

    Vue3中結(jié)合ElementPlus實(shí)現(xiàn)彈窗的封裝方式

    這篇文章主要介紹了Vue3中結(jié)合ElementPlus實(shí)現(xiàn)彈窗的封裝方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-01-01
  • Vue監(jiān)視數(shù)據(jù)的原理詳解

    Vue監(jiān)視數(shù)據(jù)的原理詳解

    這篇文章主要為大家詳細(xì)介紹了Vue監(jiān)視數(shù)據(jù)的原理,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來(lái)幫助
    2022-02-02
  • vue多頁(yè)面項(xiàng)目開(kāi)發(fā)實(shí)戰(zhàn)指南

    vue多頁(yè)面項(xiàng)目開(kāi)發(fā)實(shí)戰(zhàn)指南

    一般我們的vue項(xiàng)目都是單頁(yè)面的,其實(shí)因?yàn)関ue在工程化開(kāi)發(fā)的時(shí)候依賴了webpack,webpack幫我們將所有的資源整合到一起而形成一個(gè)單頁(yè)面,下面這篇文章主要給大家介紹了關(guān)于vue多頁(yè)面項(xiàng)目開(kāi)發(fā)的相關(guān)資料,需要的朋友可以參考下
    2022-01-01
  • 解讀Vue-loader的相關(guān)知識(shí)

    解讀Vue-loader的相關(guān)知識(shí)

    這篇文章主要介紹了解讀Vue-loader的相關(guān)知識(shí),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-03-03
  • 解決vue無(wú)法設(shè)置滾動(dòng)位置的問(wèn)題

    解決vue無(wú)法設(shè)置滾動(dòng)位置的問(wèn)題

    這篇文章主要介紹了解決vue無(wú)法設(shè)置滾動(dòng)位置的問(wèn)題 ,需要的朋友可以參考下
    2018-10-10
  • Vue3利用縮放進(jìn)行屏幕分辨率適配的解決方案講解

    Vue3利用縮放進(jìn)行屏幕分辨率適配的解決方案講解

    本文詳細(xì)解析了如何在Vue3中實(shí)現(xiàn)一個(gè)自動(dòng)根據(jù)設(shè)計(jì)寬度縮放并調(diào)整高度的響應(yīng)式組件,組件的核心功能包括設(shè)計(jì)寬度設(shè)定、動(dòng)態(tài)縮放比例計(jì)算和高度調(diào)整,文中通過(guò)代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2024-09-09
  • vue實(shí)現(xiàn)文件上傳和下載

    vue實(shí)現(xiàn)文件上傳和下載

    這篇文章主要為大家詳細(xì)介紹了vue實(shí)現(xiàn)文件上傳和下載,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-08-08
  • vue集成百度UEditor富文本編輯器使用教程

    vue集成百度UEditor富文本編輯器使用教程

    這篇文章主要為大家詳細(xì)介紹了vue集成百度UEditor富文本編輯器的使用教程,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2018-09-09
  • vue中過(guò)濾器filter的講解

    vue中過(guò)濾器filter的講解

    今天小編就為大家分享一篇關(guān)于vue中過(guò)濾器filter的講解,小編覺(jué)得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來(lái)看看吧
    2019-01-01
  • 淺談vite和webpack的性能優(yōu)化和區(qū)別

    淺談vite和webpack的性能優(yōu)化和區(qū)別

    本文主要介紹了淺談vite和webpack的區(qū)別,從性能優(yōu)化的幾個(gè)方便講解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2023-05-05

最新評(píng)論