diff --git a/.env.development b/.env.development
new file mode 100644
index 0000000..3cbedc9
--- /dev/null
+++ b/.env.development
@@ -0,0 +1,5 @@
+# 开发环境变量
+ENV = 'development'
+
+# base api
+VUE_APP_BASE_API = '/dev-api'
diff --git a/.env.production b/.env.production
new file mode 100644
index 0000000..bb0b6af
--- /dev/null
+++ b/.env.production
@@ -0,0 +1,6 @@
+# 生产环境变量
+ENV = 'production'
+
+# base api
+VUE_APP_BASE_API = '/prod-api'
+
diff --git a/.env.staging b/.env.staging
new file mode 100644
index 0000000..2bf35d5
--- /dev/null
+++ b/.env.staging
@@ -0,0 +1,6 @@
+# 模拟环境变量
+ENV = 'staging'
+
+# base api
+VUE_APP_BASE_API = '/stage-api'
+
diff --git a/package.json b/package.json
index 552b0ca..1e2fedd 100644
--- a/package.json
+++ b/package.json
@@ -2,8 +2,8 @@
"name": "vue3-element-admin",
"version": "0.0.0",
"scripts": {
- "dev": "vite",
- "build": "vue-tsc --noEmit && vite build",
+ "dev": "vite serve --mode development",
+ "build:prod": "vue-tsc --noEmit && vite build --mode production",
"serve": "vite preview"
},
"dependencies": {
@@ -13,6 +13,7 @@
"vuex": "^4.0.2"
},
"devDependencies": {
+ "@types/node": "^16.11.7",
"@vitejs/plugin-vue": "^1.9.3",
"typescript": "^4.4.3",
"vite": "^2.6.4",
diff --git a/src/App.vue b/src/App.vue
index 77bcfac..8fd9ce7 100644
--- a/src/App.vue
+++ b/src/App.vue
@@ -1,8 +1,3 @@
-
diff --git a/src/components/HelloWorld.vue b/src/components/HelloWorld.vue
index 3f21801..86b7718 100644
--- a/src/components/HelloWorld.vue
+++ b/src/components/HelloWorld.vue
@@ -1,42 +1,27 @@
-
-
+
+ 点击+1
-
-
diff --git a/src/store/index.ts b/src/store/index.ts
index 4abb398..1368867 100644
--- a/src/store/index.ts
+++ b/src/store/index.ts
@@ -1,5 +1,5 @@
import {InjectionKey} from 'vue'
-import {createStore, Store} from 'vuex'
+import {createStore,useStore as baseUseStore ,Store} from 'vuex'
export interface State {
count: number
@@ -20,6 +20,7 @@ export const store = createStore({
}
})
-
-
+export function userStore(){
+ return baseUseStore(key)
+}
diff --git a/tsconfig.json b/tsconfig.json
index 8f6afaa..dae1699 100644
--- a/tsconfig.json
+++ b/tsconfig.json
@@ -9,8 +9,16 @@
"sourceMap": true,
"resolveJsonModule": true,
"esModuleInterop": true,
- "lib": ["esnext", "dom"]
- },
- "include": ["src/**/*.ts", "src/**/*.d.ts", "src/**/*.tsx", "src/**/*.vue"],
+ "lib": ["esnext", "dom"],
+ /* Vite 路径别名报错 */
+ "baseUrl": "./",
+ "paths": {
+ "@": ["src"],
+ "@/*": ["src/*"]
+ },
+
+ "skipLibCheck": true // element-plus 生产打包报错,通过此配置修改 TS 不对第三方依赖类型检查
+ },
+ "include": ["src/**/*.ts", "src/**/*.d.ts", "src/**/*.tsx", "src/**/*.vue"]
}
diff --git a/vite.config.ts b/vite.config.ts
index 315212d..9b95f46 100644
--- a/vite.config.ts
+++ b/vite.config.ts
@@ -1,7 +1,43 @@
-import { defineConfig } from 'vite'
+import {defineConfig} from 'vite'
import vue from '@vitejs/plugin-vue'
+// 在 ts 模块中加载 node 核心模块需要安装 node 的类型补充模块: npm i -D @types/node
+import path from 'path'
+
// https://vitejs.dev/config/
export default defineConfig({
- plugins: [vue()]
+ plugins: [vue()],
+ resolve: {
+ // Vite2设置别名路径方式一
+ /**
+ alias:{
+
+ "/@":path.resolve("./src"),
+ },
+ **/
+
+ // Vite2设置别名路径方式二
+ alias: [
+ {
+ find: "@",
+ replacement: path.resolve("./src")
+ },
+ {
+ find: "@image",
+ replacement: path.resolve("./src/assets/images")
+ },
+ {
+ find: "@router",
+ replacement: path.resolve("./src/router")
+ },
+ {
+ find: "@store",
+ replacement: path.resolve("./src/store")
+ },
+ {
+ find: "@api",
+ replacement: path.resolve("./src/api")
+ }
+ ]
+ }
})