AgentSkillsCN

frontend

前端模式:组件设计、状态管理、性能优化、无障碍访问。适用于构建 Web 前端、组件,或客户端应用时使用。

SKILL.md
--- frontmatter
name: frontend
description: "Frontend patterns: component design, state management, performance, accessibility. Use when building web frontends, components, or client-side apps."
allowed-tools: Read, Write, Edit, Bash, Grep, Glob

前端开发模式

本技能提供前端开发的最佳实践和模式,支持多框架按需加载。

触发条件

  • 创建或修改前端组件
  • 设计 UI/UX 交互
  • 实现状态管理
  • 性能优化
  • 无障碍开发

框架专属模式

根据项目技术栈,加载对应的框架专属文件:

技术栈加载文件框架
Vuevue.mdVue 3, Nuxt 3
Reactreact.mdReact 18, Next.js
Sveltesvelte.mdSvelte, SvelteKit
Angularangular.mdAngular 17+

加载方式: 检测项目中的 package.json 依赖确定技术栈。


通用组件模式

组件分类

code
┌─────────────────────────────────────────────────────┐
│                    组件金字塔                         │
├─────────────────────────────────────────────────────┤
│  页面组件 (Pages/Views)                              │
│  ├─ 负责路由和布局                                   │
│  ├─ 组合多个功能组件                                 │
│  └─ 管理页面级状态                                   │
├─────────────────────────────────────────────────────┤
│  功能组件 (Features/Containers)                      │
│  ├─ 包含业务逻辑                                     │
│  ├─ 连接状态管理                                     │
│  └─ 调用 API                                        │
├─────────────────────────────────────────────────────┤
│  UI 组件 (UI/Presentational)                        │
│  ├─ 纯展示,无业务逻辑                               │
│  ├─ 通过 props 接收数据                              │
│  └─ 通过 events 通知父组件                           │
├─────────────────────────────────────────────────────┤
│  基础组件 (Base/Primitives)                         │
│  ├─ Button, Input, Card 等                          │
│  ├─ 高度可复用                                       │
│  └─ 设计系统基础                                     │
└─────────────────────────────────────────────────────┘

组件设计原则

原则说明
单一职责一个组件只做一件事
Props 向下数据从父组件流向子组件
Events 向上事件从子组件通知父组件
组合优于继承使用 slot/children 组合组件
可预测相同 props 产生相同输出

命名规范

code
components/
├── ui/                    # 基础组件(PascalCase)
│   ├── Button.vue/tsx
│   ├── Input.vue/tsx
│   └── Card.vue/tsx
├── feature/               # 功能组件(PascalCase)
│   ├── UserCard.vue/tsx
│   └── OrderList.vue/tsx
└── layout/                # 布局组件(PascalCase)
    ├── Header.vue/tsx
    └── Sidebar.vue/tsx

状态管理模式

状态分层

层级范围存储方式示例
组件状态单个组件useState/ref表单输入、UI 状态
共享状态多个组件Context/Store用户信息、主题
服务器状态来自 APIQuery Cache列表数据、详情
URL 状态路由参数Router页码、筛选条件
持久状态跨会话localStorage用户偏好

状态管理选择

code
简单共享状态 → Context/Provide
  ↓ 复杂度增加
中等应用 → Pinia/Zustand
  ↓ 复杂度增加
大型应用 → Redux/Vuex + 规范化

服务器状态管理

code
API 请求 → Query Library(TanStack Query)
  ├─ 自动缓存
  ├─ 重新验证
  ├─ 乐观更新
  └─ 错误重试

性能优化模式

渲染优化

技术用途框架实现
Memoization避免重复计算useMemo/computed
Lazy Loading延迟加载组件lazy/defineAsyncComponent
Virtual List大列表渲染react-window/vue-virtual-scroller
Code Splitting按需加载代码动态 import

资源优化

code
图片优化:
├─ 响应式图片(srcset)
├─ 懒加载(loading="lazy")
├─ 现代格式(WebP/AVIF)
└─ 图片 CDN

脚本优化:
├─ Tree Shaking
├─ Bundle 分析
├─ 预加载关键资源
└─ 延迟非关键脚本

性能指标

指标目标说明
LCP< 2.5s最大内容绘制
FID< 100ms首次输入延迟
CLS< 0.1累积布局偏移
TTI< 3.8s可交互时间

无障碍模式 (a11y)

基础清单

  • 语义化 HTML - 使用正确的元素(button, nav, main...)
  • 键盘可访问 - 所有交互可用键盘完成
  • 焦点管理 - 焦点顺序合理,焦点可见
  • ARIA 标签 - 为动态内容添加适当标签
  • 颜色对比 - 符合 WCAG 2.1 AA 标准(4.5:1)
  • 替代文本 - 图片有 alt,图标有 aria-label

常见 ARIA 模式

html
<!-- 按钮 -->
<button aria-label="关闭菜单" aria-expanded="false">
  <Icon name="close" aria-hidden="true" />
</button>

<!-- 表单 -->
<input
  aria-labelledby="label-id"
  aria-describedby="hint-id error-id"
  aria-invalid="true"
/>

<!-- 动态内容 -->
<div aria-live="polite" aria-busy="false">加载完成</div>

<!-- 对话框 -->
<div role="dialog" aria-modal="true" aria-labelledby="dialog-title">
  <h2 id="dialog-title">对话框标题</h2>
</div>

键盘交互

元素按键行为
按钮Enter/Space激活
链接Enter导航
菜单↑↓移动焦点
对话框Esc关闭
Tab列表←→切换标签

表单模式

表单验证

code
客户端验证:
├─ 实时验证(onChange)
├─ 提交验证(onSubmit)
├─ 字段级错误
└─ 表单级错误

验证库:
├─ React: react-hook-form + zod
├─ Vue: vee-validate + zod
└─ 通用: yup/zod

表单状态

code
{
  values: {},        // 字段值
  errors: {},        // 验证错误
  touched: {},       // 字段已交互
  isSubmitting: false,
  isValid: true
}

错误处理

html
<!-- 字段错误 -->
<div class="field">
  <label for="email">邮箱</label>
  <input id="email" aria-invalid="true" aria-describedby="email-error" />
  <span id="email-error" role="alert" class="error">
    请输入有效的邮箱地址
  </span>
</div>

<!-- 表单级错误 -->
<div role="alert" class="form-error">提交失败:网络错误,请重试</div>

动画模式

动画类型

类型用途实现
进入/退出元素出现/消失CSS Transition
状态变化hover/activeCSS Transition
列表动画添加/删除/排序FLIP 动画
页面切换路由过渡路由动画
复杂动画多阶段动画Framer Motion/GSAP

动画原则

  1. 有意义 - 动画应该传达信息
  2. 快速 - 持续时间 150-300ms
  3. 可禁用 - 尊重 prefers-reduced-motion
  4. 不阻塞 - 不影响用户操作

减少动画

css
@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }
}

设计美学(避免 AI Slop)

核心理念

创造独特、令人难忘的界面,而非千篇一律的"AI 风格"。

❌ 避免的通用 AI 美学

类别避免的模式
字体Inter, Roboto, Arial, system-ui 等通用字体
配色紫色渐变配白底、蓝-紫配色、彩虹渐变
布局居中卡片、对称网格、模板化 Hero 区
动画通用淡入淡出、无意义的脉冲效果
元素毛玻璃卡片泛滥、通用图标、stock 图片

✅ 追求的设计方向

维度做法
字体选择有个性的字体,标题和正文字体形成对比
配色提交一个主导色,用锐利的强调色,避免平均分配
布局不对称、重叠、对角线流动、打破网格、负空间或密度控制
动画聚焦高影响力时刻:精心编排的页面加载、交错出现、滚动触发
背景渐变网格、噪点纹理、几何图案、透明层、阴影深度

设计决策流程

code
1. 理解上下文
   - 这个界面解决什么问题?
   - 目标用户是谁?
   - 品牌调性如何?

2. 选择美学方向(极端化)
   - 极简主义 vs 极繁主义
   - 复古未来 vs 自然有机
   - 奢华精致 vs 玩具活泼
   - 杂志编辑 vs 粗野主义
   - 装饰艺术 vs 工业实用

3. 确定记忆点
   - 用户会记住什么?
   - 什么让这个设计**独一无二**?

4. 执行到位
   - 大胆的极繁需要丰富的代码、动画、特效
   - 精炼的极简需要克制、精准、细节打磨

代码示例

css
/* ❌ 通用 AI 风格 */
.card {
  font-family: Inter, system-ui;
  background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
  border-radius: 16px;
  box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
}

/* ✅ 有个性的设计 */
.card {
  font-family: "Space Mono", monospace; /* 或其他独特字体 */
  background:
    linear-gradient(180deg, transparent 0%, rgba(0, 0, 0, 0.8) 100%),
    url("noise.svg");
  border: 1px solid rgba(255, 255, 255, 0.1);
  clip-path: polygon(
    0 0,
    100% 0,
    100% calc(100% - 20px),
    calc(100% - 20px) 100%,
    0 100%
  );
  /* 斜切角设计,打破圆角卡片的惯例 */
}

记住

Claude 有能力创造非凡的作品。不要保守,展示真正跳出框架、全身心投入独特视觉的设计。


测试模式

测试金字塔

code
       △ E2E 测试
      ╱  ╲ 少量关键流程
     ╱────╲
    △ 集成测试
   ╱  ╲ 组件交互、API 调用
  ╱────────╲
 △ 单元测试
╱  ╲ 工具函数、纯组件
╱──────────────╲

组件测试原则

code
测试用户行为,而非实现细节:
├─ ✅ 点击按钮后显示文本
├─ ❌ 检查 state 变量值
├─ ✅ 输入文字后表单提交
└─ ❌ 检查内部方法调用

测试库

框架单元/集成E2E
ReactTesting LibraryPlaywright/Cypress
VueTesting LibraryPlaywright/Cypress
通用VitestPlaywright

框架专属内容

详细的框架专属实现请参考:

专项优化

  • 性能优化: performance.md - Core Web Vitals (LCP/INP/CLS)
  • Tailwind CSS: tailwind.md - Tailwind 最佳实践 + v4 迁移指南
  • 设计指南: design-guide.md - Designer 角色设计方法论与审查清单

Maintenance

  • Sources: MDN, WCAG 2.1, web.dev, 各框架官方文档
  • Last updated: 2025-01-22
  • Pattern: 通用清单 + 按需加载框架专属