diff --git a/.env.development b/.env.development
index faaac77..3890df1 100644
--- a/.env.development
+++ b/.env.development
@@ -1,8 +1,9 @@
# 运行环境
-VITE_ENV=development
+VITE_PROD = false
+VITE_DEV = true
-# api域名
-VITE_API_URL = 'YOUR API URL'
+# BASE_URL
+VITE_BASE_URL = http://api-catch.ranesuangyu.top
# 上传域名
VITE_UPLOAD_URL = 'YOUR UPLOAD URL'
\ No newline at end of file
diff --git a/.env.production b/.env.production
index d521e59..4a7c385 100644
--- a/.env.production
+++ b/.env.production
@@ -1,8 +1,9 @@
# 运行环境
-VITE_ENV=production
+VITE_PROD = true
+VITE_DEV = false
# api域名
-VITE_API_URL = 'YOUR API URL'
+VITE_BASE_URL = 'YOUR API URL'
# 上传域名
VITE_UPLOAD_URL = 'YOUR UPLOAD URL'
diff --git a/.vscode/settings.json b/.vscode/settings.json
new file mode 100644
index 0000000..a466545
--- /dev/null
+++ b/.vscode/settings.json
@@ -0,0 +1,3 @@
+{
+ "i18n-ally.localesPaths": []
+}
\ No newline at end of file
diff --git a/package.json b/package.json
index 46fb821..c85295c 100644
--- a/package.json
+++ b/package.json
@@ -47,6 +47,7 @@
"@dcloudio/uni-mp-toutiao": "3.0.0-alpha-3040820220424001",
"@dcloudio/uni-mp-weixin": "3.0.0-alpha-3040820220424001",
"@dcloudio/uni-quickapp-webview": "3.0.0-alpha-3040820220424001",
+ "lodash-es": "^4.17.21",
"vue": "^3.2.33",
"vue-i18n": "^9.1.9"
},
@@ -56,6 +57,7 @@
"@dcloudio/uni-automator": "3.0.0-alpha-3040820220424001",
"@dcloudio/uni-cli-shared": "3.0.0-alpha-3040820220424001",
"@dcloudio/vite-plugin-uni": "3.0.0-alpha-3040820220424001",
+ "@types/lodash-es": "^4.17.6",
"@types/node": "^17.0.38",
"@typescript-eslint/eslint-plugin": "^5.27.0",
"@typescript-eslint/parser": "^5.27.0",
@@ -80,7 +82,7 @@
},
"lint-staged": {
"*.{js,jsx,vue,ts,tsx}": [
- "pnpm lint",
+
"prettier --write",
"git add"
]
diff --git a/pnpm-lock.yaml b/pnpm-lock.yaml
index 632afa7..60acba1 100644
--- a/pnpm-lock.yaml
+++ b/pnpm-lock.yaml
@@ -18,6 +18,7 @@ specifiers:
'@dcloudio/uni-mp-weixin': 3.0.0-alpha-3040820220424001
'@dcloudio/uni-quickapp-webview': 3.0.0-alpha-3040820220424001
'@dcloudio/vite-plugin-uni': 3.0.0-alpha-3040820220424001
+ '@types/lodash-es': ^4.17.6
'@types/node': ^17.0.38
'@typescript-eslint/eslint-plugin': ^5.27.0
'@typescript-eslint/parser': ^5.27.0
@@ -27,6 +28,7 @@ specifiers:
eslint-plugin-vue: ^9.1.0
husky: ^8.0.1
lint-staged: ^13.0.0
+ lodash-es: ^4.17.21
mrm: ^4.0.0
prettier: ^2.6.2
sass: ^1.52.1
@@ -50,6 +52,7 @@ dependencies:
'@dcloudio/uni-mp-toutiao': registry.npmmirror.com/@dcloudio/uni-mp-toutiao/3.0.0-alpha-3040820220424001_vue@3.2.36
'@dcloudio/uni-mp-weixin': registry.npmmirror.com/@dcloudio/uni-mp-weixin/3.0.0-alpha-3040820220424001_vue@3.2.36
'@dcloudio/uni-quickapp-webview': registry.npmmirror.com/@dcloudio/uni-quickapp-webview/3.0.0-alpha-3040820220424001_vue@3.2.36
+ lodash-es: registry.npmmirror.com/lodash-es/4.17.21
vue: registry.npmmirror.com/vue/3.2.36
vue-i18n: registry.npmmirror.com/vue-i18n/9.1.10_vue@3.2.36
@@ -59,6 +62,7 @@ devDependencies:
'@dcloudio/uni-automator': registry.npmmirror.com/@dcloudio/uni-automator/3.0.0-alpha-3040820220424001_vue@3.2.36
'@dcloudio/uni-cli-shared': registry.npmmirror.com/@dcloudio/uni-cli-shared/3.0.0-alpha-3040820220424001_vue@3.2.36
'@dcloudio/vite-plugin-uni': registry.npmmirror.com/@dcloudio/vite-plugin-uni/3.0.0-alpha-3040820220424001_vite@2.9.9+vue@3.2.36
+ '@types/lodash-es': registry.npmmirror.com/@types/lodash-es/4.17.6
'@types/node': registry.npmmirror.com/@types/node/17.0.38
'@typescript-eslint/eslint-plugin': registry.npmmirror.com/@typescript-eslint/eslint-plugin/5.27.0_dszb5tb7atwkjjijmmov4qhi7i
'@typescript-eslint/parser': registry.npmmirror.com/@typescript-eslint/parser/5.27.0_xztl6dhthcahlo6akmb2bmjmle
@@ -1283,6 +1287,20 @@ packages:
'@types/node': registry.npmmirror.com/@types/node/17.0.38
dev: true
+ registry.npmmirror.com/@types/lodash-es/4.17.6:
+ resolution: {integrity: sha512-R+zTeVUKDdfoRxpAryaQNRKk3105Rrgx2CFRClIgRGaqDTdjsm8h6IYA8ir584W3ePzkZfst5xIgDwYrlh9HLg==, registry: https://registry.npm.taobao.org/, tarball: https://registry.npmmirror.com/@types/lodash-es/-/lodash-es-4.17.6.tgz}
+ name: '@types/lodash-es'
+ version: 4.17.6
+ dependencies:
+ '@types/lodash': registry.npmmirror.com/@types/lodash/4.14.182
+ dev: true
+
+ registry.npmmirror.com/@types/lodash/4.14.182:
+ resolution: {integrity: sha512-/THyiqyQAP9AfARo4pF+aCGcyiQ94tX/Is2I7HofNRqoYLgN1PBoOWu2/zTA5zMxzP5EFutMtWtGAFRKUe961Q==, registry: https://registry.npm.taobao.org/, tarball: https://registry.npmmirror.com/@types/lodash/-/lodash-4.14.182.tgz}
+ name: '@types/lodash'
+ version: 4.14.182
+ dev: true
+
registry.npmmirror.com/@types/node/17.0.38:
resolution: {integrity: sha512-5jY9RhV7c0Z4Jy09G+NIDTsCZ5G0L5n+Z+p+Y7t5VJHM30bgwzSjVtlcBxqAj+6L/swIlvtOSzr8rBk/aNyV2g==, registry: https://registry.npm.taobao.org/, tarball: https://registry.npmmirror.com/@types/node/-/node-17.0.38.tgz}
name: '@types/node'
@@ -4427,6 +4445,12 @@ packages:
p-locate: registry.npmmirror.com/p-locate/4.1.0
dev: true
+ registry.npmmirror.com/lodash-es/4.17.21:
+ resolution: {integrity: sha512-mKnC+QJ9pWVzv+C4/U3rRsHapFfHvQFoFB92e52xeyGMcX6/OlIl78je1u8vePzYZSkkogMPJ2yjxxsb89cxyw==, registry: https://registry.npm.taobao.org/, tarball: https://registry.npmmirror.com/lodash-es/-/lodash-es-4.17.21.tgz}
+ name: lodash-es
+ version: 4.17.21
+ dev: false
+
registry.npmmirror.com/lodash.camelcase/4.3.0:
resolution: {integrity: sha512-TwuEnCnxbc3rAvhf/LbG7tJUDzhqXyFnv3dtzLOPgCG/hODL7WFnsbwktkD7yUV0RrreP/l1PALq/YSg6VvjlA==, registry: https://registry.npm.taobao.org/, tarball: https://registry.npmmirror.com/lodash.camelcase/-/lodash.camelcase-4.3.0.tgz}
name: lodash.camelcase
diff --git a/src/assets/style/main.scss b/src/assets/style/main.scss
index 32d3d27..d279aa4 100644
--- a/src/assets/style/main.scss
+++ b/src/assets/style/main.scss
@@ -11,4 +11,4 @@
height: 0 !important;
-webkit-appearance: none;
background: transparent;
-}
\ No newline at end of file
+}
diff --git a/src/env.d.ts b/src/env.d.ts
index 64d18cd..68cd434 100644
--- a/src/env.d.ts
+++ b/src/env.d.ts
@@ -10,8 +10,10 @@ declare module '*.vue' {
interface ImportMetaEnv {
readonly VITE_ENV: string;
readonly VITE_APP_TITLE: string;
- readonly VITE_API_URL: string;
+ readonly VITE_BASE_URL: string;
readonly VITE_UPLOAD_URL: string;
+ readonly VITE_PROD: boolean;
+ readonly VITE_DEV: boolean;
}
interface ImportMeta {
diff --git a/src/main.ts b/src/main.ts
index 317c4ad..bbdeaa9 100644
--- a/src/main.ts
+++ b/src/main.ts
@@ -1,6 +1,9 @@
import { createSSRApp } from 'vue';
import App from './App.vue';
import 'virtual:windi.css';
+import { setupInterceptors } from '@/utils/interceptors';
+
+setupInterceptors();
export function createApp() {
const app = createSSRApp(App);
return {
diff --git a/src/pages.json b/src/pages.json
index 8a92cfb..6bbf9ca 100644
--- a/src/pages.json
+++ b/src/pages.json
@@ -6,6 +6,12 @@
"style": {
"navigationBarTitleText": "uni-app"
}
+ },
+ {
+ "path": "pages/login/index",
+ "style": {
+ "navigationBarTitleText": "登录"
+ }
}
],
"globalStyle": {
diff --git a/src/pages/index/index.vue b/src/pages/index/index.vue
index aae13e4..1befb45 100644
--- a/src/pages/index/index.vue
+++ b/src/pages/index/index.vue
@@ -4,7 +4,11 @@
{{ title }}
+ {{ url }} ----
+
+
+
@@ -12,6 +16,15 @@
import { ref } from 'vue';
import Test from '@/components/test/Test.vue';
const title = ref('Hello');
+ const url = import.meta.env.VITE_BASE_URL;
+ console.log('url', url);
+ const jumLogin = () => {
+ console.log('/pages/login/index');
+
+ // uni.navigateTo({
+ // url: '/pages/login/index',
+ // });
+ };
diff --git a/src/utils/http/request/index.ts b/src/utils/http/request/index.ts
new file mode 100644
index 0000000..431953b
--- /dev/null
+++ b/src/utils/http/request/index.ts
@@ -0,0 +1,69 @@
+const BASE_URL = import.meta.env.VITE_BASE_URL;
+function createRequest(options: RequestOptions) {
+ const _options = Object.assign({}, options);
+ return new Promise((resolve, reject) => {
+ uni.request({
+ ..._options,
+ success(res) {
+ const { statusCode, data: resData } = res;
+ if (statusCode === 200) {
+ const { code, data, message } = resData;
+ switch (code) {
+ case 10000:
+ resolve(resData);
+ break;
+ case 10001:
+ default:
+ reject(resData);
+ break;
+ }
+ }
+ },
+ fail(err) {
+ reject(err);
+ },
+ });
+ });
+}
+
+export const request = createRequest;
+
+function beforeRequestInterceptors(args: any) {
+ uni.showLoading({});
+ args.url = `${BASE_URL}${args.url}`;
+ args.dataType = 'json';
+ args.responseType = 'text';
+ args.header = {
+ 'Content-Type': 'application/json;charset=UTF-8;',
+ Accept: 'application/json, text/plain, */*',
+ };
+}
+
+function responseSuccessInterceptors(res: any) {}
+
+function responseFailInterceptors(err: any) {}
+
+function completeInterceptors(res: any) {
+ uni.hideLoading();
+}
+
+export function requestInterceptors() {
+ uni.addInterceptor('request', {
+ invoke(args) {
+ // request 触发前拦截
+ beforeRequestInterceptors(args);
+ },
+ success(res) {
+ // 响应成功后触发拦截
+ responseSuccessInterceptors(res);
+ },
+ fail(err) {
+ // 响应失败后触发拦截
+ responseFailInterceptors(err);
+ },
+ complete(res) {
+ // 响应失败后触发拦截
+ completeInterceptors(res);
+ },
+ });
+}
diff --git a/src/utils/http/request/request.d.ts b/src/utils/http/request/request.d.ts
new file mode 100644
index 0000000..b33c354
--- /dev/null
+++ b/src/utils/http/request/request.d.ts
@@ -0,0 +1 @@
+declare type RequestOptions = UniApp.RequestOptions;
diff --git a/src/utils/interceptors/index.ts b/src/utils/interceptors/index.ts
new file mode 100644
index 0000000..c50750a
--- /dev/null
+++ b/src/utils/interceptors/index.ts
@@ -0,0 +1,5 @@
+import { requestInterceptors } from '@/utils/http/request';
+
+export function setupInterceptors() {
+ requestInterceptors();
+}
diff --git a/tsconfig.json b/tsconfig.json
index 8a7712f..5d9c79f 100644
--- a/tsconfig.json
+++ b/tsconfig.json
@@ -15,5 +15,11 @@
"@/*":["./src/*"]
}
},
- "include": ["src/**/*.ts", "src/**/*.d.ts", "src/**/*.tsx", "src/**/*.vue"]
+ "include": [
+ "src/**/*.ts",
+ "src/**/*.d.ts",
+ "src/**/*.tsx",
+ "src/**/*.vue",
+ "node_modules/**/uni.d.ts"
+ ]
}
diff --git a/vite.config.ts b/vite.config.ts
index 1715213..5eb591e 100644
--- a/vite.config.ts
+++ b/vite.config.ts
@@ -37,11 +37,11 @@ export default defineConfig({
// 设计稿的像素宽度值,该尺寸会影响 rpx 转换过程中的计算比率
designWidth: 350,
}),
- eslintPlugin({
- include: ['src/**/*.js', 'src/**/*.vue', 'src/**/*.ts'],
- exclude: ['./node_modules/**'],
- cache: false,
- }),
+ // eslintPlugin({
+ // include: ['src/**/*.js', 'src/**/*.vue', 'src/**/*.ts'],
+ // exclude: ['./node_modules/**'],
+ // cache: false,
+ // }),
],
css: {
preprocessorOptions: {