vue3+ts封裝axios實(shí)例以及解決跨域問題
一、前言
前端請(qǐng)求后端數(shù)據(jù)時(shí),會(huì)用到axios,但是如果不將axios封裝好,會(huì)導(dǎo)致代碼冗余
二次封裝的好處如下:
- 求頭能統(tǒng)一處理
- 便于接口的統(tǒng)一管理
- 解決回調(diào)地獄
- 配置攔截器,給不同的實(shí)例配置不同的攔截器,支持以對(duì)象形式接受多個(gè)攔截器配置
因此,在這里記錄一下axios的封裝過程。
二、封裝axios
安裝axios
npm install axios
在目錄/src/utils
下創(chuàng)建一個(gè)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, // 請(qǐng)求超時(shí)時(shí)間 headers:{ 'Content-Type': 'application/json;charset=UTF-8', } }); // 請(qǐng)求攔截器 instance.interceptors.request.use( config => { // 在發(fā)送請(qǐng)求之前做些什么,例如添加token // config.headers['Authorization'] = 'Bearer your-token'; return config; }, error => { // 對(duì)請(qǐng)求錯(cuò)誤做些什么 return Promise.reject(error); } ); // 響應(yīng)攔截器 instance.interceptors.response.use( response => { // 對(duì)響應(yīng)數(shù)據(jù)做點(diǎn)什么 return response; }, error => { // 對(duì)響應(yīng)錯(cuò)誤做點(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
文件的目的是為了方便管理接口,你可以把所有接口卸載這里,這樣就會(huì)在后面調(diào)用時(shí)更加簡(jiǎn)潔
三、 解決跨域
在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é)果
可以看到控制臺(tái)返回的亂碼數(shù)據(jù),表示我們請(qǐng)求后臺(tái)成功了
總結(jié)
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
vue 實(shí)現(xiàn)input表單元素的disabled示例
今天小編就為大家分享一篇vue 實(shí)現(xiàn)input表單元素的disabled示例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來(lái)看看吧2019-10-10如何在vue項(xiàng)目中使用UEditor--plus
UEditor是由百度web前端研發(fā)部開發(fā)的所見即所得的開源富文本編輯器,這篇文章主要介紹了如何在vue項(xiàng)目中使用UEditor--plus?,需要的朋友可以參考下2022-08-08Vue如何實(shí)現(xiàn)將后端返回二進(jìn)制文件在瀏覽器自動(dòng)下載
Vue項(xiàng)目開發(fā)中,遇到界面下載功能時(shí),前端如何實(shí)現(xiàn)將后端返回二進(jìn)制文件在瀏覽器自動(dòng)下載呢,本文就來(lái)和大家聊聊具體的解決方法吧2024-11-11vue-router(this.$router)如何在新窗口打開路由跳轉(zhuǎn)頁(yè)面
這篇文章主要介紹了vue-router(this.$router)如何在新窗口打開路由跳轉(zhuǎn)頁(yè)面問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-12-12詳解el Cascader懶加載數(shù)據(jù)回顯示例
這篇文章主要為大家介紹了詳解el Cascader懶加載數(shù)據(jù)回顯示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-11-11Vue-cli Eslint在vscode里代碼自動(dòng)格式化的方法
本篇文章主要介紹了Vue-cli Eslint在vscode里代碼自動(dòng)格式化的方法,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來(lái)看看吧2018-02-02vue函數(shù)input輸入值請(qǐng)求時(shí)延遲1.5秒請(qǐng)求問題
這篇文章主要介紹了vue函數(shù)input輸入值請(qǐng)求時(shí)延遲1.5秒請(qǐng)求問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-04-04詳解vue項(xiàng)目中使用token的身份驗(yàn)證的簡(jiǎn)單實(shí)踐
這篇文章主要介紹了vue項(xiàng)目中使用token的身份驗(yàn)證的簡(jiǎn)單實(shí)踐,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-03-03