fec-vite-project-standardlisted
Install: claude install-skill bovinphang/frontend-craft
# Vite 项目规范
适用于 Vite 应用、组件库、开发服务器和构建配置的设计与审查。
## 用途
规范 Vite 配置、安全边界和构建性能,避免开发环境与生产构建的常见陷阱。
## 流程
1. 识别项目类型
- 应用项目优先检查 `root`、`base`、`server.proxy`、`envPrefix`、`build` 和框架插件。
- 组件库项目优先检查 `build.lib`、类型产物、peer dependencies external 和导出入口。
- Monorepo 额外检查 `server.fs.allow`、路径别名和包依赖边界。
2. 选择插件
- React 默认优先 `@vitejs/plugin-react-swc`;需要 Babel 插件时才用 `@vitejs/plugin-react`。
- Vue 项目使用 `@vitejs/plugin-vue`,路径别名优先交给 `vite-tsconfig-paths`。
- TypeScript 项目必须通过 `tsc --noEmit`、CI 或 `vite-plugin-checker` 补齐类型检查。
3. 管理环境变量
- 客户端只读取明确公开的前缀,如 `VITE_`。
- `loadEnv` 第三个参数使用显式前缀数组,不使用空字符串加载全部变量。
- 密钥、数据库地址、私有 token 必须留在服务端或构建系统,不进入客户端 bundle。
4. 优化开发体验
- 慢启动先用 `vite --profile` 定位插件、解析或预构建瓶颈。
- 对 CJS/UMD 依赖用 `optimizeDeps.include` 处理互操作问题。
- 大项目可用 `server.warmup.clientFiles` 预热核心入口。
5. 优化生产构建
- 发布前运行 `vite build`,并用 `vite preview` 做本地构建烟测。
- 手动分包使用稳定的对象形式优先,避免把每个依赖拆成独立小 chunk。
- 生产 sourcemap 默认关闭;若上传错误追踪平台,上传后不随站点公开。
- 动效、3D、图表、编辑器、地图和音视频处理库优先通过动态导入或路由级拆包隔离。
- 检查静态资源是否进入正确目录、是否被 hash/cache、是否存在占位 URL 或过大的未压缩媒体。
## 最小配置
```ts
import { defineConfig, loadEnv } from "vite";
import react from "@vitejs/plugin-react-swc";
import tsconfigPaths from "vite-tsconfig-paths";
export default defineConfig(({ mode }) => {
const env = loadEnv(mode, process.cwd(), ["VITE_"]);
return {
plugins: [react(), tsconfigPaths()],
define: {
__PUBLIC_API_URL__: JSON.stringify(env.VITE_API_URL),
},
server: {
proxy: {
"/api":