Vue 3 + Axios 完整入門實戰指南

從入門到深入,手把手教你在 Vue 3 中正確使用 Axios,支持全局掛載、局部分離、使用 proxy 連接場景,適合所有前端小白和實戰設計。

大家好,我是石小石!一個熱愛技術分享的開源社區貢獻者,小冊《油猴腳本實戰指南》作者、CSDN專欄《Vite極速入門通關教程》作者。


一、安裝 Axios

npm install axios

二、Vue 3 中將 Axios 全局掛載

Vue 3 不再支持 Vue 2 中的 Vue.prototype 方式,而是通過 app.config.globalProperties 來達到相同效果:

全局掛載

// main.js
import { createApp } from 'vue'
import App from './App.vue'
import router from './router'
import axios from 'axios'const app = createApp(App)
app.config.globalProperties.$http = axiosapp.use(router).mount("#app")

三、在組件中使用 Axios

使用 getCurrentInstance 獲取當前實例 (dev-only)

import { getCurrentInstance, onMounted } from 'vue'export default {setup() {const { ctx } = getCurrentInstance();onMounted(() => {ctx.$http.get('/api/user').then(res => console.log(res));});}
};

使用 proxy 替代 ctx (推薦)

import { getCurrentInstance, onMounted } from 'vue'export default {setup() {const { proxy } = getCurrentInstance();onMounted(() => {proxy.$http.get('/api/user').then(res => console.log(res));});}
};

應對環境錯誤:ctx 在打包后無法訪問 globalProperties,需要使用 proxy 替代。


四、局部引入 + 分類使用

創建 /proxy/index.js

// proxy/index.js
import axios from 'axios';const getList = (url) => axios.get(url);export default {getList
};

在組件中使用

import axiosProxy from '../proxy';axiosProxy.getList('/api/todoList/list').then(res => {console.log(res.data);
});

五、Axios 基礎用法

GET 請求

axios.get('/user?id=12345').then(res => console.log(res)).catch(err => console.error(err));

POST 請求

axios.post('/user', {firstName: 'Fred',lastName: 'Flintstone'
}).then(res => console.log(res));

六、通用 config 配置

axios({method: 'post',url: '/user',data: {firstName: 'Fred'},timeout: 1000,headers: {'X-Requested-With': 'XMLHttpRequest'}
});

常用 config 項目概覽

項目說明
url請求地址
method方法 (get/post)
baseURL基礎路徑
headers請求頭
paramsurl 取值參數
data請求體數據 (post 用)
timeout超時時間

七、定義全局默認配置

axios.defaults.baseURL = 'https://api.example.com';
axios.defaults.headers.common['Authorization'] = 'Bearer token';
axios.defaults.timeout = 5000;

八、自定義實例 + 攔截器

定義一個獨立實例

const instance = axios.create({baseURL: '/api',timeout: 10000,
});

攔截器

instance.interceptors.request.use(config => {// 添加公共 tokenconfig.headers.Authorization = 'Bearer your_token';return config;
}, error => Promise.reject(error));instance.interceptors.response.use(response => {return response.data; // 簡化接口結果
}, error => Promise.reject(error));

九、返回結構

Axios 的響應包括如下結構:

{data: {},         // 接口返回數據status: 200,     // HTTP 狀態碼statusText: 'OK',headers: {},config: {},      // 當前配置request: {}      // XMLHttpRequest 對象
}

實際使用

axios.get('/user/12345').then(res => {console.log(res.data);
});

十、推薦擴展

  • 把 axios 包裝成 hooks
  • 封裝連接失敗提示 / 熱更新負載
  • 通過 provide/inject 分類控制 API 請求成本

總結

Vue 3 + Axios 是最常用的前后端通訊配置,重點是「全局 globalProperties 掛載 + proxy 替代 this + 分類 request」,這是一套無需完全依賴 UI 框架的經典組合技術路線,非常適合工程化開發和小組件開發。

關于我

最近在學習油猴腳本開發,寫了很多有趣的腳本:

  • 接口攔截工具:修改CSDN博客數據接口返回值

  • Vue路由一鍵切換:開發效率起飛

  • 任意元素雙擊實現畫中畫:摸魚超級助手

  • 掘金后臺自動簽到助手

  • 解除文本復制、網頁復制、一鍵下載為MD

  • 主題切換助手

如果你對油猴腳本開發也感興趣,可以參考我的油猴腳本開發教程

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/910449.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/910449.shtml
英文地址,請注明出處:http://en.pswp.cn/news/910449.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

CppCon 2017 學習:Effective Qt: 2017 Edition

這段內容講的是 Qt 容器(Qt Containers)和標準庫容器(STL Containers)之間的選擇和背景: 主要觀點: Qt 容器的歷史背景 Qt 自身帶有一套容器類(如 QList, QVector, QMap 等)&#…

Pandas 核心數據結構詳解:Series 和 DataFrame 完全指南

1. 前言:為什么需要 Pandas 數據結構? 在數據處理和分析中,我們需要高效的方式來存儲和操作結構化數據。Python 原生的列表(List)和字典(Dict)雖然靈活,但缺乏針對數據分析的優化。…

使用 Solscan API 的開發指南:快速獲取 Solana 鏈上數據

Solana 生態中有多個區塊瀏覽器,其中 Solscan 提供了功能全面的 API,適用于查詢地址資產、Solana 生態中有多個區塊瀏覽器,其中 Solscan 提供了功能全面的 API,適用于查詢地址資產、交易詳情、合約交互等多種開發場景。相比直接使…

高效工具-libretv

什么是libretv? LibreTV 是一個輕量級、免費的在線視頻搜索與觀看平臺,提供來自多個視頻源的內容搜索與播放服務。無需注冊,即開即用,支持多種設備訪問。項目結合了前端技術和后端代理功能,可部署在支持服務端功能的各類網站托管…

回溯----5.括號生成

題目鏈接 /** 合法括號生成規則: 第一個括號必須是左括號(第一個為右必定無法閉合) 選擇過程中左括號數量必須小于n才可選擇左括號(大于n則一定有括號無法閉合) 左括號數量必須大于右括號數量才可選擇右括號(相等代表所有前驅括號都已閉合) 所需參數: left 記錄已選擇左括號數…

【weaviate】分布式數據寫入之LSM樹深度解析:讀寫放大的權衡

文章目錄 一、LSM樹的設計哲學:寫優化的根本動機1、 傳統B樹存儲的性能瓶頸2、 LSM樹的根本性創新 二、寫入路徑的深度技術分析1、 WAL機制的精密設計2、 MemTable的數據結構3、 刷盤(Flush)過程的技術細節 三、Compaction策略:LS…

Pygame 大魚吃小魚

【Pygame 大魚吃小魚】是一款基于Python編程語言和Pygame庫開發的趣味游戲。Pygame是Python中一個廣泛用于開發2D游戲的開源模塊集合,它提供了豐富的功能,如窗口管理器、事件處理、圖形繪制等,使得初學者也能快速上手創建游戲。 這段 Python …

【為什么在觸發的事件中修改控件屬性需要使用`Invoke`】

在C#中,特別是在使用Windows Forms或WPF等GUI框架時,控件的屬性和狀態通常只能在創建它們的線程(即UI線程,即主線程或用戶界面線程)中直接修改。這是由于這些框架的設計基于單線程模型,其中所有與用戶界面&…

Android 當apk是系統應用時,無法使用webView的解決方案

最近在做項目時,遇到了一個無法使用webView的問題,apk是系統應用,點擊加載webView時應用就是崩潰,原因是系統應用時,Android會覺得webView不安全,不避讓加載。 解決的思路就是使用映射,把原生的…

ArcGIS Pro無插件加載(無偏移)天地圖!一次添加長久使用

以前我們介紹過:ArcGIS無插件加載(無偏移)天地圖。這次我們來介紹ArcGIS Pro中如何添加天地圖。 我們將通過從天地圖官網自己添加服務鏈接并添加至收藏的方式以及應急的方法來做本次的介紹。天地圖的數據主要包括影像、電子地圖、地形圖等。我…

Go堆內存管理

# Go堆內存管理 1. Go內存模型層級結構 Golang內存管理模型與TCMalloc的設計極其相似。基本輪廓和概念也幾乎相同,只是一些規則和流程存在差異。 2. Go內存管理的基本概念 Go內存管理的許多概念在TCMalloc中已經有了,含義是相同的,只是名字…

零售 EDI:Chewy EDI 項目注意事項

在此前的文章《供應商對接Chewy的EDI需求》中,介紹了Chewy的EDI需求,本文主要為大家分享Chewy對于各個業務單據的細節性需求,了解這些細節性注意事項將幫助企業快速基于知行軟件提供的EDI服務與Chewy建立EDI對接。 基于知行之橋EDI系統能夠通…

Android錄制視頻自帶鋪滿多行水印

文章目錄 引言環境要求代碼實現總結 引言 之前做過幾種水印需求,這篇文章是關于使用Android原生庫開發錄制視頻自帶滿幀文字水印。 環境要求 Android 7.0以上Android Studio ,官方開發者官網視頻錄制功能參考開源庫PictureSelector的camerax庫 //用到的…

觀遠ChatBI:加速零售消費企業數據驅動的敏捷決策

近年來,隨著國產大模型(如DeepSeek)的快速發展,企業對智能化數據分析工具的需求日益增長。觀遠數據推出的ChatBI,基于大語言模型(LLM)打造,旨在通過自然語言交互降低數據分析門檻&am…

鴻蒙NEXT-鴻蒙三層架構搭建,嵌入HMRouter,實現便捷跳轉,新手攻略。(1/3)

接下來,我將手把手帶領大家去完善,搭建一個鴻蒙的三層架構,另實現HMRouter的嵌入。完成后,大家可任意跳轉頁面,在三層架構中,書寫屬于自己的篇章。 第0步,項目與AGC華為控制臺關聯起來 首先AG…

鴻蒙ArkTs仿網易云音樂項目:架構剖析與功能展示

鴻蒙ArkTs仿網易云音樂項目:架構剖析與功能展示 一、引言 在移動應用開發的浪潮中,音樂類應用始終占據著重要的一席之地。網易云音樂憑借其豐富的音樂資源、個性化的推薦算法和獨特的社交互動功能,深受廣大用戶的喜愛。本文將詳細介紹一個基…

【web 安全】從 HTTP 無狀態到現代身份驗證機制

文章目錄 Web 安全與系統設計Web存在的問題:Web 是無狀態的解決方案一、早期解決方案:Session Cookie 的誕生二、第二階段:Token 的出現(前后端分離 移動端的解決方案)三、分析總結:1.早期版本&#xff1…

FlutterUnit TolyUI | 布局游樂場

FlutterUnit 基于 TolyUI 大大簡化了界面構建的代碼復雜程度,因此之前想要實現的一些小功能,就可以輕松支持。布局游樂場是通過交互的方式來 直觀體驗 組件的布局特性,從而更易學和掌握。目前 FlutterUnit 已在 知識集錄模塊新增了 布局寶庫&…

【數據分析一:Data Collection】信息檢索

本節內容含有各典型數據集的推薦,以及其網址,大家根據需要自取 一、檢索 最簡單、最靈活的數據獲取方式就是依靠檢索: Google:更適合搜索英文信息 Google Dataset Search(Google 數據集搜索) 網址&…

23.ssr和csr的對比?如何依賴node.js實現

1.為什么說ssr 的node中間層請求速度快。相當于內網? 那vue.js加載怎么沒有ssr和csr的說法啊 第一問:為什么說 SSR 的 Node 中間層請求速度快?是不是相當于內網? ? 是的,本質上就是「內網請求」,所以更快…