KWC Vue 开发专家
本 Skill 是 KWC Vue 项目开发的入口与总指挥。基于 Vue 3 (Composition API + <script setup>) 进行开发。
核心职责
你负责指导用户进行 KWC Vue 组件的开发、修改和维护。
重要:你必须严格遵守本 Skill 目录下的 rule.md 文件中定义的硬性约束。在开始任何代码编写前,请务必阅读并理解这些规则。
1. 环境上下文确认
- 项目根目录:包含
.kd文件夹和app/kwc目录。 - 配置环境:
.kd/config.json中framework为vue。 - 重要:若当前环境不满足上述条件,必须立即停止使用本 Skill 的所有约束,转而按通用 Vue Web 项目标准协助用户。
2. Vue 3 开发基础
本项目基于 Vue 3,必须遵循以下基本原则:
- Composition API:统一使用
<script setup>语法,禁止使用 Options API(export default { data(), methods, computed, watch }) - 响应式:使用
ref()/reactive()声明响应式状态,禁止使用this。向 Web Components 传递复杂数据(对象/数组)时,由于底层需检测引用变化,绝对禁止push或splice原地修改,必须通过重新赋值(如data.value = [...data.value, new])产生新引用来触发渲染。 - 生命周期:使用
onMounted()/onUnmounted()等 Composition API 钩子 - 模板语法:
- 属性绑定:
:prop="value" - 事件绑定:
@sl-change="handler"(Shoelace 组件使用@sl-*前缀) - 向 Web Component 传递对象/数组属性:必须用 camelCase +
.prop修饰符:【✅ 正确】 <sl-table :dataSource.prop="rows" :columns.prop="cols" :rowSelection.prop="sel"></sl-table> 【❌ 错误】 <sl-table :data-source="rows" :row-selection="sel"></sl-table> - 数字类型属性使用 camelCase 不需
.prop(如:pageSize="20");字符串/布尔属性必须用 camelCase(如rowKey="id"、showHeader、simpleMode),禁止 kebab-case(如row-key、show-header)
- 属性绑定:
- TypeScript:推荐使用
<script setup lang="ts">
3. 标准工作流 (Workflow)
-
新建组件:
- 必须使用 CLI 工具,严禁手工创建文件:
kd project create [组件名] --type kwc - 组件命名遵循
PascalCase。
- 必须使用 CLI 工具,严禁手工创建文件:
-
代码实现与修改:
- 学习:优先参考
app/kwc/exampleComponent。 - 严格合规:代码必须符合本 Skill 目录下的
rule.md中的所有约束(导入规范、事件绑定等)。 - Shoelace 集成:涉及 Shoelace 组件时,确保从 correct path 导入。
- 学习:优先参考
-
验证与交付:
- 按项目入口更新
app/kwc/main*引用。 - 运行
npm run dev进行验证。
- 按项目入口更新
4. 关键约束摘要 (详细请见本 Skill 目录下的 rule.md)
- 导入:
import '@kdcloudjs/shoelace/dist/components/input/input.js'; - 模板:使用
<sl-input>(kebab-case)。 - 事件:使用
@sl-change绑定。 - CSS:样式必须使用 Shoelace Design Token(
var(--sl-color-*)、var(--sl-spacing-*)、var(--sl-font-size-*)、var(--sl-border-radius-*)),禁止硬编码 hex 色值和 px 数值。详见./reference/css-design-tokens.md。
5. 常用资源
- 扩展组件文档(位于本 Skill 的
reference/目录下):- Table:
reference/table/index.md - DatePicker:
reference/datepicker/index.md - TimePicker:
reference/sl-timepicker.md - Pagination:
reference/sl-pagination.md - Nav:
reference/sl-nav.md - 使用前必须阅读相应文档。
- Table:
- 标准组件文档:https://shoelace.style/
6. 输出检查清单
提交代码前,请自查:
- 使用 Vue 3 Composition API (
<script setup>),未使用 Options API - 新建组件使用了
kd project create [组件名] --type kwc - 已阅读并遵守本 Skill 目录下的
rule.md中的所有约束 - 导入了所有使用的 Web Components
- 模板标签为 kebab-case
- 事件使用
@sl-* - 未运行任何 ESLint/Prettier 修复命令,并忽略了所有 ESLint 格式报错