@plugin-light/project-config-uni-vite
Version:
开箱即用的项目配置,适用于 uni-app Vue3.x 项目
133 lines (132 loc) • 3.89 kB
TypeScript
/// <reference types="node" />
import type { BuildOptions, CommonServerOptions, Plugin, ServerOptions } from 'vite';
import tailwindcss from 'tailwindcss';
import type { Options as RemoveSelectorOptions } from '@plugin-light/postcss-plugin-remove-selector';
import type { Options as TransformWebTagOptions } from '@plugin-light/postcss-plugin-transform-web-tag';
import type { ICrossGameStyleOptions } from '@plugin-light/vite-plugin-cross-game-style';
import type { IRemoveVueDirectionOptions } from '@plugin-light/vite-plugin-remove-vue-directive';
import type { UniTailwindPluginUserOptions } from '@uni-helper/vite-plugin-uni-tailwind';
import type { Options as LegacyOptions } from '@vitejs/plugin-legacy';
import type { Server } from 'node:https';
import type { Options as ESBuildOptions } from 'rollup-plugin-esbuild';
export interface IUniViteConfigOptions {
/**
* 模式
*/
mode: string;
/**
* uni 插件
*/
uni: any;
/**
* 端口,传递给 server.port
*
* @default 443
*/
port?: CommonServerOptions['port'];
/**
* https 配置,传递给 server.https
*/
https?: Server;
/**
* host 配置,传递给 server.host
* @default true
*/
host?: CommonServerOptions['host'];
/**
* 前置插件
*/
prePlugins?: Array<Plugin>;
/**
* 后置插件
*/
postPlugins?: Array<Plugin>;
/**
* 对应 optimizeDeps.include
*/
optimizeDepsIncludes?: Array<string>;
/**
* remove-vue-direction 插件参数
*/
removeVueDirectionOptions?: IRemoveVueDirectionOptions;
/**
* hmr 选项
* @default { timeout: 1000 * 60 * 5 }
*/
hmr?: ServerOptions['hmr'];
/**
* 语法警报列表,比如 v-model,destroyed
*/
warnList?: ICrossGameStyleOptions['warnList'];
/**
* transform-web-tag postcss 插件参数
*/
transformWebTagOptions?: boolean | TransformWebTagOptions;
/**
* remove selector postcss 插件参数
*/
removeSelectorOptions?: boolean | RemoveSelectorOptions;
/**
* uniTailwind 插件参数
*/
uniTailwindOptions?: boolean | UniTailwindPluginUserOptions;
/**
* tailwindcss postcss 插件参数
*/
tailwindcssOptions?: boolean | Parameters<typeof tailwindcss>[0];
/**
* 构建选项
*/
buildOptions?: BuildOptions;
/**
* 是否使用 chunk-split
* @default false
*/
useChunkSplit?: boolean;
/**
* 是否使用 @vitejs/plugin-legacy,传递对象格式将作为插件参数
* @default false
*/
useLegacy?: boolean | LegacyOptions;
/**
* 传递给 uni 插件的参数
*/
uniOptions?: any;
/**
* 是否使用 rollup-plugin-esbuild,传递对象格式将作为插件参数
*/
useESBuildPlugin?: boolean | ESBuildOptions;
/**
* 是否使用 pmd-network-v2
* @default false
*/
usePMDNetworkV2?: boolean;
/**
* 是否使用文件轮询监听(usePolling)
*
* 轮询比原生 fs.watch 慢且 CPU 占用高,仅在 Docker/WSL 等不支持 inotify 的环境下需要开启
* @default true
*/
usePolling?: boolean;
/**
* 是否开启 visualizer 产物分析插件
*
* 设为 false 可跳过 gzip/brotli 计算,加快构建速度
* @default true
*/
useVisualizer?: boolean;
/**
* 是否使用 @rollup/plugin-node-resolve
*
* Vite 内部已有 resolve 能力,关闭可减少重复解析开销
* @default true
*/
useNodeResolve?: boolean;
/**
* 构建目标,传递给 build.target(仅 H5 生效)
*
* 如果不需要兼容旧浏览器,可设为 'es2020' 或 'esnext' 以减少 polyfill,加快构建
* @default 'es2015'
*/
buildTarget?: string;
}