import { defineConfig } from 'vite' import uni from '@dcloudio/vite-plugin-uni' import UniPages from '@uni-helper/vite-plugin-uni-pages' import UnoCSS from 'unocss/vite' import zipPack from "vite-plugin-zip-pack" import dayjs from "dayjs"; import vitePluginRemoveDir from './delete'; // 自己写的删除插件 import getPages from './build' const {exclude} = getPages(); const excludeStaticModule = exclude.filter(item => item.indexOf('.vue') === -1) // const timeStringNow = dayjs().format("YYYY-MM-DD HH-mm-ss") const timeStringNow = dayjs().format("MM-DD HH-mm-ss") export default defineConfig(({ command, mode }) => { const { UNI_PLATFORM } = process.env // 得到 mp-weixin, h5, app 等 console.log(process.env.NODE_ENV); console.log({command,mode}); return { plugins: [ UniPages({ exclude: ['**/components/**/**.*',...exclude], routeBlockLang: 'json5', // 虽然设了默认值,但是vue文件还是要加上 lang="json5", 这样才能很好地格式化 // homePage 通过 vue 文件的 route-block 的type="home"来设定 // pages 目录为 src/pages,分包目录不能配置在pages目录下 // subPackages: ['src/pages-sub'], // 是个数组,可以配置多个,但是不能为pages里面的目录 }), uni(), vitePluginRemoveDir({dirName:excludeStaticModule}), UnoCSS(), zipPack({ inDir: `dist/build/${UNI_PLATFORM}`, // 输入的文件夹,就是要打包的文件夹 outDir: `dist/build`, // 打包好的 zip 文件放到哪个文件夹下 outFileName: `${UNI_PLATFORM}-${timeStringNow}.zip`, //文件名不能包含\/:*?"<>| pathPrefix: '' }), ] } })