mirror of
https://github.com/palxiao/poster-design
synced 2024-11-22 16:17:59 +00:00
feat: support typescript in common request files
This commit is contained in:
parent
980fd3db76
commit
c159a51146
@ -13,6 +13,7 @@ module.exports = {
|
||||
// 自定义你的规则
|
||||
'vue/component-tags-order': ['off'],
|
||||
'vue/no-multiple-template-root': ['off'],
|
||||
'max-params': ['off'],
|
||||
// 'no-undef': 'off', // 禁止使用未定义的变量,会把TS声明视为变量,暂时关闭
|
||||
},
|
||||
parserOptions: {
|
||||
|
2
.vscode/settings.json
vendored
2
.vscode/settings.json
vendored
@ -5,7 +5,7 @@
|
||||
"editor.defaultFormatter": "esbenp.prettier-vscode",
|
||||
"eslint.validate": ["javascript", "javascriptreact", "vue", "typescript", "typescriptreact"],
|
||||
"editor.codeActionsOnSave": {
|
||||
"source.fixAll.eslint": true
|
||||
"source.fixAll.eslint": "explicit"
|
||||
},
|
||||
"css.validate": false,
|
||||
"less.validate": false,
|
||||
|
@ -20,3 +20,7 @@ export default {
|
||||
QINIUYUN_PLUGIN: 'https://lf26-cdn-tos.bytecdntp.com/cdn/expire-1-M/qiniu-js/2.5.5/qiniu.min.js',
|
||||
supportSubFont: true, // 是否开启服务端字体压缩
|
||||
}
|
||||
|
||||
export const LocalStorageKey = {
|
||||
tokenKey: "xp_token"
|
||||
}
|
||||
|
8
src/env.d.ts
vendored
8
src/env.d.ts
vendored
@ -1,8 +0,0 @@
|
||||
// / <reference types="vite/client" />
|
||||
|
||||
declare module '*.vue' {
|
||||
import { DefineComponent } from 'vue';
|
||||
// eslint-disable-next-line @typescript-eslint/no-explicit-any, @typescript-eslint/ban-types
|
||||
const component: DefineComponent<{}, {}, any>;
|
||||
export default component;
|
||||
}
|
5
src/types/env.d.ts
vendored
5
src/types/env.d.ts
vendored
@ -1,4 +1,4 @@
|
||||
/// <reference lib="dom" />
|
||||
// / <reference lib="dom" />
|
||||
|
||||
interface ImportMeta {
|
||||
url: string
|
||||
@ -23,7 +23,8 @@ interface ImportMeta {
|
||||
on(event: string, cb: (...args: any[]) => void): void
|
||||
}
|
||||
|
||||
readonly env: ImportMetaEnv
|
||||
// readonly env: ImportMetaEnv
|
||||
|
||||
|
||||
glob(pattern: string): Record<
|
||||
string,
|
||||
|
@ -2,12 +2,12 @@
|
||||
* @Author: ShawnPhang
|
||||
* @Date: 2021-07-13 02:48:38
|
||||
* @Description: 本地测试项目请勿修改此文件
|
||||
* @LastEditors: ShawnPhang <https://m.palxp.cn>
|
||||
* @LastEditTime: 2024-01-11 17:36:33
|
||||
* @LastEditors: Jeremy Yu <https://github.com/JeremyYu-cn>
|
||||
* @LastEditTime: 2024-02-26 17:54:00
|
||||
*/
|
||||
import axios from 'axios'
|
||||
import axios, { AxiosRequestConfig, AxiosResponse, AxiosStatic } from 'axios'
|
||||
import store from '@/store'
|
||||
import app_config from '@/config'
|
||||
import app_config, { LocalStorageKey } from '@/config'
|
||||
|
||||
axios.defaults.timeout = 30000
|
||||
axios.defaults.headers.authorization = 'eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJpZCI6MTAwMDEsImV4cCI6MTc4ODU3NDc1MDU4NX0.L_t6DFD48Dm6rUPfgIgOWJkz18En1m_-hhMHcpbxliY';
|
||||
@ -16,15 +16,15 @@ const baseUrl = app_config.API_URL
|
||||
|
||||
// 请求拦截器
|
||||
axios.interceptors.request.use(
|
||||
(config: Type.Object) => {
|
||||
(config: AxiosRequestConfig) => {
|
||||
// const access_token = store.state.currentUser.access_token;
|
||||
const url = config.url
|
||||
const url = config.url ?? ""
|
||||
const values = {}
|
||||
// values.access_token = access_token;
|
||||
// values.version = version;
|
||||
|
||||
if (url.indexOf('http://') !== 0 && url.indexOf('https://') !== 0) {
|
||||
url.indexOf('/') === 0 ? (config.url = baseUrl + url) : (config.url = baseUrl + '/' + url)
|
||||
if (!url.startsWith('http://') && !url.startsWith('https://')) {
|
||||
config.url = url.startsWith('/') ? baseUrl + url : config.url = baseUrl + '/' + url
|
||||
}
|
||||
|
||||
if (config.method === 'get') {
|
||||
@ -44,10 +44,8 @@ axios.interceptors.request.use(
|
||||
)
|
||||
|
||||
// 响应拦截器
|
||||
axios.interceptors.response.use(
|
||||
(res: Type.Object) => {
|
||||
axios.interceptors.response.use((res: AxiosResponse<any>) => {
|
||||
// store.dispatch('hideLoading');
|
||||
|
||||
// 接口规则:只有正确code为200时返回result结果对象,错误返回整个结果对象
|
||||
|
||||
if (!res.data) {
|
||||
@ -74,16 +72,28 @@ axios.interceptors.response.use(
|
||||
},
|
||||
)
|
||||
|
||||
type TFetchRequestConfigParams = AxiosRequestConfig & Record<string, any>
|
||||
type TFetchMethod = keyof Pick<
|
||||
AxiosStatic,
|
||||
"get" | "post" | "put" | "getUri" | "request" | "delete" | "head" | "options" | "patch"
|
||||
>
|
||||
|
||||
// export default axios;
|
||||
const fetch = (url: string, params: Type.Object, type: string | undefined = 'get', exheaders: Type.Object = {}, extra: any = {}) => {
|
||||
if (params && params._noLoading) {
|
||||
const fetch = (
|
||||
url: string,
|
||||
params: TFetchRequestConfigParams,
|
||||
type: TFetchMethod = 'get',
|
||||
exheaders: Record<string, any> = {},
|
||||
extra: Record<string, any> = {}
|
||||
) => {
|
||||
if (params?._noLoading) {
|
||||
delete params._noLoading
|
||||
} else {
|
||||
// store.commit('loading', '加载中..');
|
||||
}
|
||||
|
||||
const token = localStorage.getItem('xp_token')
|
||||
const headerObject: Type.Object = { }
|
||||
const token = localStorage.getItem(LocalStorageKey.tokenKey)
|
||||
const headerObject: Record<string, any> = {}
|
||||
token && (headerObject.authorization = token)
|
||||
|
||||
if (type === 'get') {
|
||||
@ -93,7 +103,7 @@ const fetch = (url: string, params: Type.Object, type: string | undefined = 'get
|
||||
...extra,
|
||||
})
|
||||
} else {
|
||||
return (axios as Type.Object)[type](url, params, {
|
||||
return axios[type](url, params, {
|
||||
headers: Object.assign(headerObject, exheaders),
|
||||
...extra,
|
||||
})
|
||||
|
@ -1,8 +1,9 @@
|
||||
<!--
|
||||
* @Author: ShawnPhang
|
||||
* @Date: 2023-09-18 17:34:44
|
||||
* @Description:
|
||||
* @Description:
|
||||
* @LastEditors: Jeremy Yu <https://github.com/JeremyYu-cn>
|
||||
* @LastUpdateContent: Support typescript
|
||||
* @LastEditTime: 2024-02-25 14:51:00
|
||||
-->
|
||||
<template>
|
||||
|
Loading…
Reference in New Issue
Block a user