Vue3使用axios的配置教程

axios中文网站:axios-http.com/zh/

一、安装axios

npm install axios --save

二、配置axios,添加拦截器

在src目录下新建一个request文件夹,在里面新建index.ts(或者.js)文件,编辑代码如下:

import axios from 'axios'

// 创建一个 axios 实例
const service = axios.create({
	baseURL: '/api', // 所有的请求地址前缀部分
	timeout: 60000, // 请求超时时间毫秒
	withCredentials: true, // 异步请求携带cookie
	headers: {
		// 设置后端需要的传参类型
		'Content-Type': 'application/json',
		'token': 'your token',
		'X-Requested-With': 'XMLHttpRequest',
	},
})

// 添加请求拦截器
service.interceptors.request.use(
	function (config) {
		// 在发送请求之前做些什么
		return config
	},
	function (error) {
		// 对请求错误做些什么
		console.log(error)
		return Promise.reject(error)
	}
)

// 添加响应拦截器
service.interceptors.response.use(
	function (response) {
		console.log(response)
		// 2xx 范围内的状态码都会触发该函数。
		// 对响应数据做点什么
		// dataAxios 是 axios 返回数据中的 data
		const dataAxios = response.data
		// 这个状态码是和后端约定的
		const code = dataAxios.reset
		return dataAxios
	},
	function (error) {
		// 超出 2xx 范围的状态码都会触发该函数。
		// 对响应错误做点什么
		console.log(error)
		return Promise.reject(error)
	}
)

export default service

三、使用axios发送请求

在src目录下新建一个apis文件夹,这里面放入今后所有的请求文件,例如新建一个请求用户信息的接口user.ts,代码如下:

// 导入axios实例
import httpRequest from '@/request/index'

// 定义接口的传参
interface UserInfoParam {
	userID: string,
	userName: string
}

// 获取用户信息
export function apiGetUserInfo(param: UserInfoParam) {
    return httpRequest({
		url: 'your api url',
		method: 'post',
		data: param,
	})
}

接着在具体业务页面里使用这个请求,例如:

<script setup lang="ts">
import { onMounted } from 'vue'
import { apiGetUserInfo } from '@/apis/user'

function getUserInfo() {
	const param = {
		userID: '10001',
		userName: 'Mike',
	}
	apiGetUserInfo(param).then((res) => {
		console.log(res)
	})
}

onMounted(() => {
	getUserInfo()
})
</script>
  • 31
    点赞
  • 181
    收藏
    觉得还不错? 一键收藏
  • 18
    评论
Vue3中配置axios需要以下几个步骤: 1. 首先,在项目根目录下通过npm安装axiosvue-axios依赖,可以使用以下命令进行安装:`npm install --save axios vue-axios` 2. 在src根目录下创建一个service文件夹,并在该文件夹内创建一个axios.js文件。 3. 在axios.js文件中引入axios库和服务文件:`import axios from "axios";` 4. 创建一个axios实例并进行相关配置,例如设置超时时间:`const initAxios = axios.create({ timeout: 1800000 })` 5. 在axios.js文件中添加请求拦截器和响应拦截器。请求拦截器可以在发送请求前做一些操作,例如添加请求头信息。响应拦截器可以处理返回的数据,例如判断响应结果是否成功:`initAxios.interceptors.request.use(...)`,`initAxios.interceptors.response.use(...)` 6. 最后,导出这个axios实例供其他地方使用:`export default () => initAxios` 在Vue3中使用axios的步骤如下: 1. 在需要使用axios的组件或文件中引入axios服务:`import _service from "@/service";` 2. 使用axios发送请求,可以调用之前定义的接口方法,例如调用getList接口:`_service.getList({你的参数}).then(res => { console.log(res) })` 请注意,Vue3中没有this关键字,所以可以直接引用axios服务。如果项目较大,接口较多,可以将接口分模块定义,并在使用时分模块导入。例如,在admin模块中定义接口。 以上就是在Vue3中配置axios使用axios的方法。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [Vue3使用axios配置教程详解](https://blog.csdn.net/qq_38682174/article/details/125416084)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 18
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值