当前位置: 首页 > news >正文

Axios 在 Vue3 项目中的使用:从安装到组件中的使用

在这里插入图片描述

🤍 前端开发工程师、技术日更博主、已过CET6
🍨 阿珊和她的猫_CSDN博客专家、23年度博客之星前端领域TOP1
🕠 牛客高级专题作者、打造专栏《前端面试必备》 、《2024面试高频手撕题》、《前端求职突破计划》
🍚 蓝桥云课签约作者、上架课程《Vue.js 和 Egg.js 开发企业级健康管理项目》、《带你从入门到实战全面掌握 uni-app》

Axios 是一个基于 promise 的 HTTP 客户端,用于浏览器和 node.js。在 Vue3 项目中,你可以使用 Axios 来发送 HTTP 请求。

安装 Axios

首先,你需要安装 Axios:

npm install axios

或者使用 yarn:

yarn add axios

在 Vue3 中使用 Axios

你可以在 Vue3 的 setup 函数中使用 Axios 发送请求。以下是一个基本的例子:

import { ref } from 'vue';
import axios from 'axios';export default {
setup() {
const responseData = ref(null);
const error = ref(null);const fetchData = async () => {
try {
const result = await axios.get('https://api.example.com/data');
responseData.value = result.data;
} catch (err) {
error.value = err;
}
};// 调用 fetchData 函数来获取数据
fetchData();return {
responseData,
error
};
}
};

在组件中使用 Axios

你可以在组件的方法中使用 Axios,或者在 onMounted 生命周期钩子中调用它来在组件加载时获取数据。

使用方法

<template>
<div v-if="error">An error occurred: {{ error.message }}</div>
<div v-else-if="responseData">
<!-- 渲染响应数据 -->
</div>
</template><script>
import { ref, onMounted } from 'vue';
import axios from 'axios';export default {
setup() {
const responseData = ref(null);
const error = ref(null);const fetchData = async () => {
try {
const result = await axios.get('https://api.example.com/data');
responseData.value = result.data;
} catch (err) {
error.value = err;
}
};onMounted(() => {
fetchData();
});return {
responseData,
error
};
}
};
</script>

使用 Axios 拦截器

Axios 允许你设置请求和响应拦截器,这可以在全局或实例级别进行。

全局拦截器

axios.interceptors.request.use(config => {
// 在发送请求之前做些什么
return config;
}, error => {
// 对请求错误做些什么
return Promise.reject(error);
});axios.interceptors.response.use(response => {
// 对响应数据做点什么
return response;
}, error => {
// 对响应错误做点什么
return Promise.reject(error);
});

实例拦截器

const instance = axios.create({
baseURL: 'https://some-domain.com/api/',
timeout: 1000,
headers: {'X-Custom-Header': 'foobar'}
});instance.interceptors.request.use(config => {
// 在发送请求之前做些什么
return config;
}, error => {
// 对请求错误做些什么
return Promise.reject(error);
});

总结

Axios 是一个强大的 HTTP 客户端,可以很容易地在 Vue3 项目中使用。通过使用 Composition API,你可以将 Axios 请求集成到 setup 函数中,使得数据获取逻辑更加清晰和模块化。记得处理好错误,并在需要时使用拦截器来统一处理请求和响应。

相关文章:

  • XSS-labs的1-18关
  • 60天python训练营打卡day38
  • 【StarRocks系列】查询优化
  • C 语言结构体:从基础到内存对齐深度解析
  • springboot垃圾分类网站
  • 响应式数据的判断:Vue3中的方法
  • 学c++ cpp 可以投递哪些岗位
  • AI大模型(四)openAI应用实战
  • 大模型在急性弥漫性腹膜炎预测及治疗方案制定中的应用研究
  • rt-thread中使用usb官方自带的驱动问题记录
  • MySQL存储引擎与架构
  • 【Datawhale组队学习202506】零基础学爬虫 02 数据解析与提取
  • 在Docker网络中,同一网络下的容器可以直接通过内部端口通信,无需经过主机端口映射,这是由Docker的网络隔离和内部通信机制决定的。
  • Python 邻接表详细实现指南
  • LeetCode第279题_完全平方数
  • DeepSeek生成HTML5生命天数计算器
  • Qt实战:自定义二级选项框 | 附完整源码
  • PCL 点云旋转的轴角表示法
  • 细节/数学/滑动窗口
  • python版halcon环境配置
  • 图片版小说网站源码/网页制作教程
  • 自动跳转手机网站/seo教程免费
  • 淘宝基地网站怎么做/如何做电商新手入门
  • 一个空间可以做多少个网站/百度竞价推广方案范文
  • 项目/网页seo是什么意思
  • 南京网站建设网/域名收录批量查询