/** * 参考文档 * https://blog.csdn.net/m0_63281537/article/details/126699761 */ import { useFetch } from '#app'; import type { UseFetchOptions } from '#app'; import {getBaseUrl, isArray} from '~/utils/tool'; export const useRequest = (url: string, opts?: UseFetchOptions) => { // 获取 Cookie const token = useCookie('token'); const defaultOptions: UseFetchOptions = { baseURL: getBaseUrl(), onRequest({ options }) { options.headers = (options.headers || {}) as { [key: string]: string }; if (token.value) { options.headers.Authorization = token.value; } options.headers.tenantid = `5`; }, onResponse({ response }) { if (+response.status === 0 && +response._data.code !== 0) { process.client && ElMessage.error(response._data.message); } if(+response.status === 500){ ElMessage.error('网络请求错误') } return response._data.data; }, onResponseError({ response }) { process.client && ElMessage.error(isArray(response._data.data.message) ? response._data.data.message[0] : response._data.data.message); } }; console.log('请求接口:', getBaseUrl() + '+' + url) return useFetch(getBaseUrl() + url, { ...defaultOptions, ...opts } as any); };