vue3+ts封裝axios實(shí)例以及解決跨域問題
一、前言
前端請求后端數(shù)據(jù)時,會用到axios,但是如果不將axios封裝好,會導(dǎo)致代碼冗余
二次封裝的好處如下:
- 求頭能統(tǒng)一處理
- 便于接口的統(tǒng)一管理
- 解決回調(diào)地獄
- 配置攔截器,給不同的實(shí)例配置不同的攔截器,支持以對象形式接受多個攔截器配置
因此,在這里記錄一下axios的封裝過程。
二、封裝axios
安裝axios
npm install axios
在目錄/src/utils下創(chuàng)建一個http的文件夾

request.ts文件內(nèi)容如下:
import axios from 'axios';
// 創(chuàng)建 axios 實(shí)例
const instance = axios.create({
baseURL: 'http://127.0.0.1:4008/api/', // API 基礎(chǔ)路徑
timeout: 100000, // 請求超時時間
headers:{
'Content-Type': 'application/json;charset=UTF-8',
}
});
// 請求攔截器
instance.interceptors.request.use(
config => {
// 在發(fā)送請求之前做些什么,例如添加token
// config.headers['Authorization'] = 'Bearer your-token';
return config;
},
error => {
// 對請求錯誤做些什么
return Promise.reject(error);
}
);
// 響應(yīng)攔截器
instance.interceptors.response.use(
response => {
// 對響應(yīng)數(shù)據(jù)做點(diǎn)什么
return response;
},
error => {
// 對響應(yīng)錯誤做點(diǎn)什么
return Promise.reject(error);
}
);
export default instance;
api.ts文件如下:
import http from './request'
export const generateVoice = (params:any) => {
return http.request({
method: 'POST',
url: '/generate_voice',
headers: {
'Content-Type': 'application/json'
},
data:JSON.stringify(params)
})
}api.ts文件的目的是為了方便管理接口,你可以把所有接口卸載這里,這樣就會在后面調(diào)用時更加簡潔
三、 解決跨域
在vite.config.ts文件中添加如下配置
server: {
port: 4008,
host: '0.0.0.0',
proxy: {
"/api": {
target: "http://64.176.215.21:8000/",
changeOrigin: false,
ws: true,
rewrite:(path) => path.replace(/^\/api/, "")
}
},
},注意 配置以上文件,你的接口就需要每次帶上/api前綴
在request.ts文件中,我們已經(jīng)做好了每次帶上/api前綴的代碼
baseURL: 'http://127.0.0.1:4008/api/', // API 基礎(chǔ)路徑 //or baseURL: '/api/', // API 基礎(chǔ)路徑
四、調(diào)用接口
沒有使用api.ts的接口
axios.post('/generate_voice',param)
.then(response => {
console.log(response);
})
.catch(error => {
console.error(error);
});使用api.ts封裝好的接口
import {generateVoice} from '@/utils/http/api';
generateVoice(param)
.then(response => {
console.log("Voice generated successfully:", response.data);
})
.catch(error => {
console.error("Error generating voice:", error);
});五、運(yùn)行結(jié)果
可以看到控制臺返回的亂碼數(shù)據(jù),表示我們請求后臺成功了

總結(jié)
以上為個人經(jīng)驗(yàn),希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
vue 實(shí)現(xiàn)input表單元素的disabled示例
今天小編就為大家分享一篇vue 實(shí)現(xiàn)input表單元素的disabled示例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-10-10
Vue如何實(shí)現(xiàn)將后端返回二進(jìn)制文件在瀏覽器自動下載
Vue項目開發(fā)中,遇到界面下載功能時,前端如何實(shí)現(xiàn)將后端返回二進(jìn)制文件在瀏覽器自動下載呢,本文就來和大家聊聊具體的解決方法吧2024-11-11
vue-router(this.$router)如何在新窗口打開路由跳轉(zhuǎn)頁面
這篇文章主要介紹了vue-router(this.$router)如何在新窗口打開路由跳轉(zhuǎn)頁面問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2023-12-12
詳解el Cascader懶加載數(shù)據(jù)回顯示例
這篇文章主要為大家介紹了詳解el Cascader懶加載數(shù)據(jù)回顯示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-11-11
Vue-cli Eslint在vscode里代碼自動格式化的方法
本篇文章主要介紹了Vue-cli Eslint在vscode里代碼自動格式化的方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-02-02
vue函數(shù)input輸入值請求時延遲1.5秒請求問題
這篇文章主要介紹了vue函數(shù)input輸入值請求時延遲1.5秒請求問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-04-04
詳解vue項目中使用token的身份驗(yàn)證的簡單實(shí)踐
這篇文章主要介紹了vue項目中使用token的身份驗(yàn)證的簡單實(shí)踐,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-03-03

