k5web/config/vite.config.base.ts

94 lines
2.7 KiB
TypeScript
Raw Permalink Normal View History

2024-01-24 13:40:15 +00:00
import { resolve } from 'path';
import { defineConfig } from 'vite';
import vue from '@vitejs/plugin-vue';
import vueJsx from '@vitejs/plugin-vue-jsx';
import svgLoader from 'vite-svg-loader';
import configArcoStyleImportPlugin from './plugin/arcoStyleImport';
2024-02-04 07:13:25 +00:00
import AutoImport from 'unplugin-auto-import/vite';
import Components from 'unplugin-vue-components/vite';
import { TDesignResolver } from 'unplugin-vue-components/resolvers';
2024-02-04 09:11:30 +00:00
import { ArcoResolver } from 'unplugin-vue-components/resolvers';
2024-02-04 07:13:25 +00:00
2024-07-02 02:55:12 +00:00
import htmlPlugin from "vite-plugin-html-config";
2024-01-24 13:40:15 +00:00
export default defineConfig({
2024-02-04 20:04:55 +00:00
base: './',
2024-01-24 13:40:15 +00:00
plugins: [
vue(),
vueJsx(),
svgLoader({ svgoConfig: {} }),
configArcoStyleImportPlugin(),
2024-02-04 07:13:25 +00:00
AutoImport({
resolvers: [TDesignResolver({
library: 'vue-next'
})],
}),
Components({
resolvers: [TDesignResolver({
library: 'vue-next'
2024-02-04 09:11:30 +00:00
}), ArcoResolver()],
2024-02-04 07:13:25 +00:00
}),
2024-07-02 02:55:12 +00:00
htmlPlugin({
metas: [
{
name: "builtTime",
content: Math.ceil(parseInt(new Date().toISOString().replace(/[.:TZ-]/g, '')) / 1000).toString()
},
]
})
2024-01-24 13:40:15 +00:00
],
resolve: {
alias: [
{
find: '@',
replacement: resolve(__dirname, '../src'),
},
{
find: 'assets',
replacement: resolve(__dirname, '../src/assets'),
},
{
find: 'vue-i18n',
replacement: 'vue-i18n/dist/vue-i18n.cjs.js', // Resolve the i18n warning issue
},
{
find: 'vue',
replacement: 'vue/dist/vue.esm-bundler.js', // compile template
},
],
2024-02-04 07:13:25 +00:00
extensions: ['.ts', '.js', '.css'],
2024-01-24 13:40:15 +00:00
},
define: {
'process.env': {},
},
css: {
preprocessorOptions: {
less: {
modifyVars: {
hack: `true; @import (reference) "${resolve(
'src/assets/style/breakpoint.less'
)}";`,
},
javascriptEnabled: true,
},
},
2024-08-04 05:39:01 +00:00
postcss: {
plugins: [
require('postcss-px-to-viewport')({
viewportWidth: 2560, // 视口宽度,对应设计稿宽度
2024-08-04 06:22:35 +00:00
viewporHeight: 1440, // 视口高度,对应设计稿高度
2024-08-04 05:39:01 +00:00
unitPrecision: 3, // 指定px转换之后的小数位数
viewportUnit: 'vw', // 转换的单位
fontViewportUnit: 'vw', // 字体使用的单位
replace: false, // 是否直接更换属性值,而不添加备用属性
2024-08-04 06:22:35 +00:00
selectorBlackList: ['.ignore', '.hairlines', '.arco', '.layout', '.nav-btn'], // 指定不转换的类
2024-08-04 05:39:01 +00:00
exclude: /(\/|\\)(node_modules)(\/|\\)/, //禁止更改第三方UI框架样式
minPixelValue: 15, // 小于或等于1px不转换
mediaQuery: true, // 允许在媒体查询中转换
})
]
}
2024-01-24 13:40:15 +00:00
},
});