Commit 038f9429 authored by sunguoshu's avatar sunguoshu

修改配置

parent 418356dd
/**
* 解析环境变量
*/
export function parseEnv(env: Record<string, string>): Record<string, any> {
const ret = {}
for (const [key, value] of Object.entries(env)) {
// 判断是不是数字
if (/^\d+$/.test(value)) {
ret[key] = Number(value)
}
// 判断是不是布尔值
else if (value === 'true' || value === 'false') {
ret[key] = value === 'true'
}
// 判断是不是对象
else if (value.startsWith('{') && value.endsWith('}')) {
try {
ret[key] = JSON.parse(value)
} catch (error) {
ret[key] = value
}
}
// 判断是不是数组
else if (value.startsWith('[') && value.endsWith(']')) {
try {
ret[key] = JSON.parse(value)
} catch (error) {
ret[key] = value
}
}
// 其他情况
else {
ret[key] = value
}
}
return ret
}
\ No newline at end of file
/**
* 插件生成
*/
import vue from '@vitejs/plugin-vue2'
import legacy from '@vitejs/plugin-legacy'
import jsx from '@vitejs/plugin-vue2-jsx'
import compressPlugin from 'vite-plugin-compression'
import autoImport from 'unplugin-auto-import/vite'
import mkcert from'vite-plugin-mkcert'
import { visualizer } from 'rollup-plugin-visualizer'
import antdvFix from 'vite-plugin-antdv-fix'
export function createPlugins(isBuild: boolean, env: any) {
const { VITE_HTTPS } = env
const plugins: any[] = [vue()]
// ployfill
plugins.push(legacy({ targets: ['> 0.01%, last 10 versions, Firefox ESR'] }))
// jsx、tsx
plugins.push(jsx())
// api自动导入
plugins.push(autoImport({ imports: ['vue', 'pinia', 'vue-router' ] }))
// https证书
if (VITE_HTTPS) {
plugins.push(mkcert({ source: 'coding' }))
}
// 打包分析
if (process.env.REPORT) {
plugins.push(visualizer({
filename: './node_modules/.cache/visualizer/stats.html',
open: true,
gzipSize: true,
brotliSize: true,
}))
}
// 打包插件
if (isBuild) {
// gzip
plugins.push(compressPlugin({
filter: /\.(js|css|html|svg)$/,
algorithm: 'gzip',
deleteOriginFile: false,
}))
}
// 修复antdv1+版本的bug
plugins.push(antdvFix())
return plugins
}
\ No newline at end of file
/**
* 本地服务器代理生成
*/
const httpsRE = /^https:\/\//
export function createProxy(proxy: any) {
const ret = {}
for (const [prefix, target] of proxy || []) {
ret[prefix] = {
target,
changeOrigin: true,
ws: true,
rewrite: path => path.replace(new RegExp(`^${prefix}`), ''),
...(httpsRE.test(target) ? { secure: false } : {}),
};
}
return ret;
}
\ No newline at end of file
...@@ -5,9 +5,10 @@ ...@@ -5,9 +5,10 @@
"type": "module", "type": "module",
"scripts": { "scripts": {
"dev": "vite", "dev": "vite",
"preview": "npm run build && vite preview",
"build": "vite build", "build": "vite build",
"build:report": "cross-env REPORT=true vite build" "build:legacy": "cross-env LEGACY=true vite build",
"build:report": "cross-env REPORT=true vite build",
"preview": "npm run build && vite preview"
}, },
"dependencies": { "dependencies": {
"a-calc": "^1.2.6", "a-calc": "^1.2.6",
...@@ -27,6 +28,7 @@ ...@@ -27,6 +28,7 @@
"devDependencies": { "devDependencies": {
"@iconify/vue2": "^2.1.0", "@iconify/vue2": "^2.1.0",
"@types/lodash": "^4.14.195", "@types/lodash": "^4.14.195",
"@types/mockjs": "^1.0.7",
"@types/node": "^20.3.2", "@types/node": "^20.3.2",
"@vitejs/plugin-legacy": "^4.0.5", "@vitejs/plugin-legacy": "^4.0.5",
"@vitejs/plugin-vue2": "^2.2.0", "@vitejs/plugin-vue2": "^2.2.0",
...@@ -43,6 +45,7 @@ ...@@ -43,6 +45,7 @@
"terser": "^5.18.2", "terser": "^5.18.2",
"typescript": "^5.1.5", "typescript": "^5.1.5",
"unplugin-auto-import": "^0.16.4", "unplugin-auto-import": "^0.16.4",
"unplugin-vue-macros": "^2.3.6",
"vite": "^4.3.9", "vite": "^4.3.9",
"vite-plugin-antdv-fix": "^1.0.3", "vite-plugin-antdv-fix": "^1.0.3",
"vite-plugin-compression": "^0.5.1", "vite-plugin-compression": "^0.5.1",
......
This diff is collapsed.
...@@ -16,7 +16,10 @@ ...@@ -16,7 +16,10 @@
"paths": { "paths": {
"@/*": ["src/*"], "@/*": ["src/*"],
"#/*": ["typings/*"] "#/*": ["typings/*"]
} },
"types": [
"unplugin-vue-macros/macros-global"
],
}, },
"include": [ "include": [
"typings/**/*.ts", "typings/**/*.ts",
...@@ -28,5 +31,16 @@ ...@@ -28,5 +31,16 @@
"auto-imports.d.ts", "auto-imports.d.ts",
"vite-env.d.ts", "vite-env.d.ts",
], ],
"references": [{ "path": "./tsconfig.node.json" }] "vueCompilerOptions": {
"plugins": [
"@vue-macros/volar/define-options",
"@vue-macros/volar/define-models",
"@vue-macros/volar/define-props",
"@vue-macros/volar/define-props-refs",
"@vue-macros/volar/short-vmodel",
"@vue-macros/volar/define-slots",
"@vue-macros/volar/export-props"
]
},
"references": [{ "path": "./tsconfig.node.json" }],
} }
import { defineConfig, loadEnv } from 'vite'
import { resolve } from 'path' import { resolve } from 'path'
import { createPlugins } from './config/plugin'; import { defineConfig, loadEnv, UserConfigExport } from 'vite'
import { createProxy } from './config/proxy'; import VueMacros from 'unplugin-vue-macros/vite'
import { parseEnv } from './config/env'; import Vue from '@vitejs/plugin-vue2'
import VueJsx from '@vitejs/plugin-vue2-jsx'
import legacy from '@vitejs/plugin-legacy'
import autoImport from 'unplugin-auto-import/vite'
import mkcert from'vite-plugin-mkcert'
import { visualizer } from 'rollup-plugin-visualizer'
import antdvFix from 'vite-plugin-antdv-fix'
import postcssImport from 'postcss-import' import postcssImport from 'postcss-import'
import autoprefixer from 'autoprefixer' import autoprefixer from 'autoprefixer'
...@@ -11,60 +15,40 @@ function pathResolve(dir: string) { ...@@ -11,60 +15,40 @@ function pathResolve(dir: string) {
return resolve(process.cwd(), '.', dir) return resolve(process.cwd(), '.', dir)
} }
export default defineConfig(({ command, mode }) => { export default defineConfig(({ mode }) => {
const root = process.cwd() const root = process.cwd()
// 加载环境变量 const env = loadEnv(mode, root)
const env = loadEnv(mode, root) as any const { VITE_PUBLIC_PATH, VITE_HTTPS, VITE_PORT } = env
const viteEnv = parseEnv(env) const isDev = mode === 'development'
const { VITE_PUBLIC_PATH, VITE_HTTPS, VITE_PORT, VITE_PROXY } = viteEnv const isLegacy = process.env.LEGACY === 'true'
const isReport = process.env.REPORT === 'true'
const isBuild = command === 'build'
return { const config: UserConfigExport = {
// 公共基础路径 root: root,
base: VITE_PUBLIC_PATH, base: VITE_PUBLIC_PATH,
resolve: { resolve: {
// 路径别名 alias: {
alias: [ '@': pathResolve('src'),
// @/xxxx => src/xxxx '#': pathResolve('typings'),
{
find: /@\//,
replacement: pathResolve('src') + '/',
},
// #/xxxx => typings/xxxx
{
find: /#\//,
replacement: pathResolve('typings') + '/',
}, },
],
}, },
// 本地开发服务器
server: { server: {
host: true, // 默认值:'localhost'。指定服务器主机名。 host: true,
port: VITE_PORT, // 默认值:5173。指定服务器端口。 port: Number(VITE_PORT),
strictPort: false, // 默认值:false。如果端口已被占用,是否抛出错误而不是自动切换到下一个可用端口。 https: VITE_HTTPS === 'true',
https: VITE_HTTPS, // 默认值:false。是否启用 https。 open: true,
open: true, // 默认值:false。是否在服务器启动时自动在浏览器中打开应用程序。 proxy: {
proxy: createProxy(VITE_PROXY), // 默认值:{}。指定开发服务器的代理规则。 '/api': {
target: 'http://192.168.4.33:9080',
rewrite: (path) => path.replace(/^\/api/, '')
}
},
}, },
// 构建配置
build: { build: {
cssTarget: 'ie11', // 默认值:'modules'。指定构建目标。
brotliSize: true, // 默认值:true。是否生成 brotli 文件大小提示。
chunkSizeWarningLimit: 2000, // 默认值:500。在构建时,如果单个文件超过指定大小(以 KB 为单位),则会在终端显示警告。
minify: 'terser', // 默认值:'terser'。指定 JS 和 CSS 的压缩器。可以是 'terser','esbuild' 或 false。
terserOptions: { // 默认值:{}。传递给 Terser 的选项。
compress: {
keep_infinity: true, // 默认值:false。保留 Infinity。
drop_console: false, // 默认值:false。是否删除 console 语句。
drop_debugger: true, // 默认值:false。是否删除 debugger 语句。
},
},
// 多页面
rollupOptions: { rollupOptions: {
input: { input: {
index: resolve(__dirname, 'index.html'), index: resolve(__dirname, 'index.html'),
...@@ -73,24 +57,46 @@ export default defineConfig(({ command, mode }) => { ...@@ -73,24 +57,46 @@ export default defineConfig(({ command, mode }) => {
} }
}, },
// css 配置
css: { css: {
preprocessorOptions: { preprocessorOptions: {
less: { less: {
javascriptEnabled: true, // 默认值:false。是否支持内联 JavaScript。 javascriptEnabled: true,
additionalData: `@import "./src/assets/style/const.less";` additionalData: `@import "./src/assets/style/global.less";`
} }
}, },
// postcss 配置
postcss: { postcss: {
plugins: [ plugins: [
postcssImport,//这个是@import postcssImport,
autoprefixer,//自动加浏览器前缀 autoprefixer,
] ]
} }
}, },
// 插件 plugins: [
plugins: createPlugins(isBuild, viteEnv), // 默认值:[]。指定用于此项目的 Vite 插件。 antdvFix(),
VueMacros({
plugins: {
vue: Vue(),
vueJsx: VueJsx(),
} }
}),
autoImport({
imports: ['vue', 'pinia', 'vue-router' ]
}),
mkcert({
source: 'coding'
}),
isLegacy && legacy({
targets: ['> 0.01%, last 10 versions, Firefox ESR']
}),
isReport && visualizer({
filename: './node_modules/.cache/visualizer/stats.html',
open: true,
gzipSize: true,
brotliSize: true,
})
],
}
return config
}) })
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment