当在TypeScript中使用axios进行网络请求时,需要先安装axios库并进行相应的类型声明安装。以下是使用axios进行GET请求的示例代码:
1.首先,安装axios和对应的类型声明:
npm install axios
npm install @types/axios
2、编写reauest.ts
import router from '@/router'
import { useUserStore } from '@/stores'
import axios, { type Method } from 'axios'
import type { Data } from '@/types/user' // 导入 返回的根部数据类型
import { showToast } from 'vant'
import 'vant/es/toast/style'
// 1.创建axios实例对象,设置 基地址,设置 获取响应超时时间
// 1.2.设置请求拦截器,剥离无效的数据,返回错误信息
// 1.3.设置响应拦截器,status状态码为200,但是 res.data.code 不等于10000,则业务错误,返回错误信息;状态码为401,则去到登录页面(清除用户信息)
// 2.导出 工具函数
const baseURL = 'https://consult-api.xxxxx.net/'
const instance = axios.create({
// TODO 1:设置基地址,请求时间
baseURL: baseURL,
timeout: 10000
})
// 请求拦截器
instance.interceptors.request.use(
(config) => {
// TODO 2:设置请求头 携带token令牌
const store = useUserStore()
if (store.user?.token && config.headers) {
config.headers['Authorization'] = `Bearer ${store.user?.token}`
console.log(config.headers.Authorization)
}
return config
},
(err) => Promise.reject(err)
)
// 响应拦截器,剥离无效的数据,401拦截并跳登录页,同时清空用户信息
instance.interceptors.response.use(
(res) => {
// 后台约定,响应成功,但是code不是10000,是业务逻辑失败
// TODO 3:处理业务失败
// TODO 4:提取核心数据
if (res.data?.code !== 10000) {
showToast(res.data?.message || '网络异常')
return Promise.reject(res.data)
}
return res.data
},
(err) => {
// TODO 5.处理401错误
if (err.response.status === 401) {
// 删除用户信息
const store = useUserStore()
store.delUser()
// 跳转登录页
router.push(`/login?returnUrl=${router.currentRoute.value.fullPath}`)
}
return Promise.reject(err)
}
)
// 工具函数
// 参数: url:字符串 method:字符串字面量 submitData: 对象
// 由于 已经在响应拦截器中 res.data
// 成功执行 .then函数
// 错误执行 .catch函数
const request = <T>(
url: string,
method: Method = 'get',
submitData?: object
) => {
return instance.request<T, Data<T>>({
// get 请求体 params,其他post请求体 data
// 设置动态属性: method===get 请求体为 params,其他post请求体 为 data
url,
method,
[method.toLowerCase() === 'get' ? 'params' : 'data']: submitData
})
}
export { baseURL, instance, request }
3.封装API
import { request } from '@/utils/request'
/**
* 获取首页-xxx-列表数据
*/
export const getKnowledgePage = (params: KnowledgeParams) => {
return request<KnowledgePage>('patient/home/knowledge', 'GET', params)
}
4.在vue中使用
import { bindMobile, loginByQQ } from '@/services/user'