检测用户使用的语言,全程使用同一语言输出。 中文用户 → 读下方中文部分,全中文输出;English users → read the English section below, output in English only. 技术术语(React、Vite、pnpm 等)保留原文即可。子技能文件为英文,AI 执行时根据用户语言输出对应语言的交互文本。
所有前端项目类型的统一入口。路由到类型专属子技能,并生成共享公共层(请求工具、全局样式、多环境配置等)。
用户: "初始化一个 React + Tailwind + Zustand 后台项目,叫 my-admin"
→ 识别类型=admin → 委派给 fe-cli-admin 快速模式
用户: "新建前端项目"
→ 询问: "什么类型?" → 路由到子技能 → 子技能询问详细问题
从用户请求中识别类型:
| 关键词 | 类型 | 子技能 |
|---|---|---|
| --- | --- | --- |
| 后台/管理/Admin/Dashboard/CRUD | admin | fe-cli-admin |
| 移动/H5/手机/微信H5/Mobile | h5 | fe-cli-h5 |
| 桌面/Electron/客户端/Desktop | electron | fe-cli-electron |
| Tauri/轻量桌面/Rust桌面 | tauri | fe-cli-tauri |
| SSR/Next.js/Nuxt/服务端渲染/SEO | ssr | fe-cli-ssr |
| 小程序/微信小程序/MiniApp/WeChat | miniapp | fe-cli-miniapp |
| React Native/RN/原生移动/App | rn | fe-cli-rn |
| Astro/Gatsby/建站/博客/文档站/VitePress | astro | fe-cli-astro |
| (默认/官网/Web/SPA/网页) | web | fe-cli-web |
如果不确定,询问:"这是什么类型的项目?Web SPA / 后台管理 / 移动H5 / Electron桌面 / Tauri桌面 / SSR / 小程序 / React Native / 静态建站"
当用户请求模糊时,必须先澄清再执行:
bun create vite / pnpm create vite 失败 → 提示用户手动创建,或检查网络/Node/Bun 版本类型识别后,读取对应子技能的 SKILL.md:
Read: ./<type>/SKILL.md (relative to fe-cli/)
每个子技能负责:
子技能生成类型专属文件后,在项目中生成以下共享文件。
Read references/shared-base.md and references/shared-config.md for code templates.
project-name/
├── src/
│ ├── components/
│ │ ├── AppProvider.tsx # 根级 Context Provider 包裹层
│ │ ├── AuthGuard.tsx # 路由鉴权守卫(角色控制)
│ │ ├── ErrorBoundary.tsx # React 错误边界
│ │ ├── GlobalLoading.tsx # 全屏 Loading 遮罩
│ │ ├── PageLoading.tsx # 页面级 Loading
│ │ ├── EmptyState.tsx # 空状态占位
│ │ └── ErrorState.tsx # 错误状态(含重试)
│ ├── config/
│ │ ├── index.ts # 应用常量 + 环境配置
│ │ └── routes.tsx # 集中式路由定义
│ ├── hooks/
│ │ ├── index.ts # Re-export all hooks
│ │ ├── useRequest.ts # 数据请求
│ │ ├── useDebounce.ts # 防抖
│ │ ├── useLocalStorage.ts # 类型安全的 localStorage
│ │ ├── useMediaQuery.ts # CSS 媒体查询响应式
│ │ ├── useClickAway.ts # 点击外部检测
│ │ ├── useToggle.ts # 布尔切换
│ │ ├── usePrevious.ts # 上一次值追踪
│ │ └── useUpdateEffect.ts # 跳过首次渲染的 effect
│ ├── layouts/
│ │ ├── AppLayout.tsx # 主布局(侧边栏 + 头部 + 内容)
│ │ ├── Header.tsx # 顶栏(主题切换、用户菜单)
│ │ └── Sidebar.tsx # 侧边导航
│ ├── locales/ # (仅 i18n 选中时生成)
│ │ ├── index.ts # i18n 初始化
│ │ ├── zh-CN.json # 中文翻译
│ │ ├── en-US.json # 英文翻译
│ │ └── useLanguage.ts # 语言切换 hook
│ ├── store/ # (仅状态管理选中时生成)
│ │ ├── index.ts # Re-export stores
│ │ ├── useUserStore.ts # 用户认证 & 信息
│ │ ├── useAppStore.ts # 应用级状态(主题、语言、侧边栏)
│ │ └── middleware.ts # 自定义中间件(logger、persist)
│ ├── theme/
│ │ ├── index.ts # ThemeProvider + 主题逻辑
│ │ ├── tokens.ts # 亮色 + 暗色设计令牌
│ │ └── useTheme.ts # 主题 hook(读取/切换/主题感知类名)
│ ├── services/
│ │ ├── request.ts # fetch 请求封装(含拦截器)
│ │ ├── logger.ts # 结构化日志(分级、轮转、持久化)
│ │ ├── log-export.ts # 日志导出(下载 .log/.json)+ 上报(待定)
│ │ └── api/
│ │ └── index.ts # API 接口定义
│ ├── styles/
│ │ ├── global.scss # CSS 变量 + 全局样式
│ │ ├── reset.scss # CSS reset
│ │ └── variables.scss # 设计令牌(颜色、间距、断点)
│ ├── utils/
│ │ ├── index.ts # 通用工具函数(防抖、深拷贝等)
│ │ ├── storage.ts # localStorage/sessionStorage 封装
│ │ ├── format.ts # 日期/数字格式化
│ │ └── validate.ts # 表单校验工具
│ └── types/
│ └── global.d.ts # 全局类型声明
├── .env # 公共环境变量
├── .env.development # 开发环境
├── .env.test # 测试环境
├── .env.production # 生产环境
└── package.json # Scripts 配置
{
"scripts": {
"dev": "vite --mode development",
"dev:test": "vite --mode test",
"build:test": "vite build --mode test",
"build:prod": "vite build --mode production",
"preview": "vite preview",
"lint": "eslint src --ext .ts,.tsx",
"lint:fix": "eslint src --ext .ts,.tsx --fix",
"typecheck": "tsc --noEmit"
}
}
基础层模板见 references/shared-base.md(含 logger.ts 和 log-export.ts)。
构建配置模板见 references/shared-config.md。
基础设施层模板见 references/shared-infrastructure.md(状态管理、主题系统、i18n、通用 Hooks、全局组件、布局、路由守卫、常量配置)。
条件生成:
src/store/src/locales/src/hooks/(通用 hooks)、src/components/AppProvider.tsx、src/components/AuthGuard.tsx、src/components/GlobalLoading.tsx、src/config/、src/theme/生成所有项目文件后,在项目根目录生成 .ai/PROJECT.md。
This file is for AI agents to quickly understand the project.
完整模板见 references/ai-project-md.md,根据具体项目类型调整目录树。
tree 命令格式(├── 和 └──),文件用一行说明bun --version 存在则用 bun,否则用 pnpmbun run 替代 node)@/ → src/.env、.env.development、.env.test、.env.productionservices/logger.ts + services/log-export.ts。使用 Logger.child("Module") 模式。最大存储 5MB 自动清理。仅开发模式控制台输出。上报端点为占位符(待定)。vercel 初始化命令pnpm.onlyBuiltDependencies 自动批准原生构建(如 @parcel/watcher)。Vite 渲染层构建命令(build:prod、build:test)不应包含 tsc -b——Vite 处理 TS 转译;类型检查是独立的 typecheck 脚本。Electron/Tauri 主进程例外:主进程代码在 Node 环境运行,需要 tsc -p tsconfig.electron.json 编译。生成项目时,AI 应主动将模板中的占位值替换为用户提供的实际值,包括但不限于:
com.example.app → 用户指定的应用 IDhttps://api.example.com → 用户指定的 API 地址My App / Your App → 用户指定的应用名称https://update.example.com → 用户指定的更新服务地址完成后提示用户确认:"项目已生成,请确认以下占位值是否正确:[列出替换后的值]"
当用户要求检查已有项目时:"检查这个前端项目"、"审查项目规范性":
package.json → 检查必要依赖和脚本## 项目审查报告
### ✅ 符合项
- [列出符合标准的条目]
### ❌ 缺失项
- [缺失项]:描述 + 建议修复方案
- ...
### ⚠️ 建议项
- [可选改进]:描述
| 检查项 | 标准 |
|---|---|
| --- | --- |
| 包管理器 | 使用 bun(优先)或 pnpm |
| 路径别名 | tsconfig + vite.config 中 @/ → src/ |
| CSS 预处理器 | 配置 Sass (SCSS) |
| 环境文件 | 存在 .env / .env.development / .env.test / .env.production |
| 请求封装 | services/request.ts 使用 fetch wrapper(非 axios) |
| 日志 | services/logger.ts 存在,使用 Logger.child("Module") 模式 |
| 全局样式 | styles/global.scss + reset.scss + variables.scss |
| 主题系统 | theme/ 目录存在,支持亮/暗模式切换 |
| 状态管理 | 若选了状态管理 → store/ 目录存在,含 userStore + appStore |
| 多语言 | 若选了 i18n → locales/ 目录存在,含 zh-CN + en-US |
| 通用 Hooks | hooks/ 目录存在,含 useDebounce、useLocalStorage、useMediaQuery 等 |
| 全局组件 | components/AppProvider.tsx + AuthGuard.tsx + GlobalLoading.tsx |
| 布局组件 | layouts/ 目录存在,含 AppLayout + Header + Sidebar |
| 路由配置 | config/routes.tsx 集中定义,非分散在各页面 |
| 常量配置 | config/index.ts 含路由路径、HTTP 状态码、分页默认值等 |
| 工具函数 | utils/index.ts + storage.ts + format.ts + validate.ts |
| 类型声明 | types/global.d.ts 含 ImportMetaEnv |
| Scripts | 含 dev / build:prod / build:test / lint / typecheck |
| .ai/PROJECT.md | 存在且与实际项目结构一致 |
fe-cli is a unified entry point for scaffolding frontend projects. It detects the project type from user input and routes to one of 9 sub-skills: web (SPA), admin (dashboard/CRUD), h5 (mobile), electron (desktop), tauri (lightweight desktop), ssr (Next.js/Nuxt), miniapp (WeChat Mini Program), rn (React Native), or astro (Astro/Gatsby/VitePress static site). Each sub-skill handles type-specific questions, file generation, and setup.
Key rules: Default package manager is bun (fallback: pnpm); default CSS preprocessor is Sass (SCSS); path alias @/ → src/; native fetch wrapper (no axios); always generate .env / .env.development / .env.test / .env.production; always generate services/logger.ts + services/log-export.ts; target Node 18+; Vite handles TS transpilation (separate typecheck script), except Electron/Tauri main process needs tsc -p tsconfig.electron.json; default deployment: Vercel; chart libs: Recharts (lightweight) / ECharts (heavy); new UI libs: shadcn/ui + Lucide (React), shadcn-vue + Vue Bits (Vue), Chakra UI, React Bits.
After type-specific files, generate the shared common layer (request utils, global styles, multi-env config, utilities, type declarations). Finally, generate .ai/PROJECT.md for AI-readability. Supports existing project audit against the same standards.
Template placeholder rule: When generating projects, AI should replace placeholders (com.example.app, https://api.example.com, etc.) with actual user-provided values and prompt the user to confirm.
Sub-skill files are in English; AI should output interaction text in the user's language during execution.
共 3 个版本