frontend-ui-engineering

安装量: 50
排名: #14649

安装

npx skills add https://github.com/addyosmani/agent-skills --skill frontend-ui-engineering

Frontend UI Engineering Overview Build production-quality user interfaces that are accessible, performant, and visually polished. The goal is UI that looks like it was built by a design-aware engineer at a top company — not like it was generated by an AI. This means real design system adherence, proper accessibility, thoughtful interaction patterns, and no generic "AI aesthetic." When to Use Building new UI components or pages Modifying existing user-facing interfaces Implementing responsive layouts Adding interactivity or state management Fixing visual or UX issues Component Architecture File Structure Colocate everything related to a component: src/components/ TaskList/ TaskList.tsx # Component implementation TaskList.test.tsx # Tests TaskList.stories.tsx # Storybook stories (if using) use-task-list.ts # Custom hook (if complex state) types.ts # Component-specific types (if needed) Component Patterns Prefer composition over configuration: // Good: Composable < Card

< CardHeader

< CardTitle

Tasks </ CardTitle

</ CardHeader

< CardBody

< TaskList tasks = { tasks } /> </ CardBody

</ Card

// Avoid: Over-configured < Card title = " Tasks " headerVariant = " large " bodyPadding = " md " content = { < TaskList tasks = { tasks } /> } /> Keep components focused: // Good: Does one thing export function TaskItem ( { task , onToggle , onDelete } : TaskItemProps ) { return ( < li className = " flex items-center gap-3 p-3 "

< Checkbox checked = { task . done } onChange = { ( ) => onToggle ( task . id ) } /> < span className = { task . done ? 'line-through text-muted' : '' }

{ task . title } </ span

< Button variant = " ghost " size = " sm " onClick = { ( ) => onDelete ( task . id ) }

< TrashIcon /> </ Button

</ li

) ; } Separate data fetching from presentation: // Container: handles data export function TaskListContainer ( ) { const { tasks , isLoading , error } = useTasks ( ) ; if ( isLoading ) return < TaskListSkeleton /> ; if ( error ) return < ErrorState message = " Failed to load tasks " retry = { refetch } /> ; if ( tasks . length === 0 ) return < EmptyState message = " No tasks yet " /> ; return < TaskList tasks = { tasks } /> ; } // Presentation: handles rendering export function TaskList ( { tasks } : { tasks : Task [ ] } ) { return ( < ul role = " list " className = " divide-y "

{ tasks . map ( task => < TaskItem key = { task . id } task = { task } /> ) } </ ul

) ; } State Management Choose the simplest approach that works: Local state (useState) → Component-specific UI state Lifted state → Shared between 2-3 sibling components Context → Theme, auth, locale (read-heavy, write-rare) URL state (searchParams) → Filters, pagination, shareable UI state Server state (React Query, SWR) → Remote data with caching Global store (Zustand, Redux) → Complex client state shared app-wide Avoid prop drilling deeper than 3 levels. If you're passing props through components that don't use them, introduce context or restructure the component tree. Design System Adherence Avoid the AI Aesthetic AI-generated UI has recognizable patterns. Avoid all of them: AI Default Production Quality Purple/indigo everything Use the project's actual color palette Excessive gradients Flat or subtle gradients matching the design system Rounded everything (rounded-2xl) Consistent border-radius from the design system Generic hero sections Content-first layouts Lorem ipsum-style copy Realistic placeholder content Oversized padding everywhere Consistent spacing scale Stock card grids Purpose-driven layouts Shadow-heavy design Subtle or no shadows unless the design system specifies Spacing and Layout Use a consistent spacing scale. Don't invent values: / Use the scale: 0.25rem increments (or whatever the project uses) / / Good / padding : 1 rem ; / 16px / / Good / gap : 0.75 rem ; / 12px / / Bad / padding : 13 px ; / Not on any scale / / Bad / margin-top : 2.3 rem ; / Not on any scale / Typography Respect the type hierarchy: h1 → Page title (one per page) h2 → Section title h3 → Subsection title body → Default text small → Secondary/helper text Don't skip heading levels. Don't use heading styles for non-heading content. Color Use semantic color tokens: text-primary , bg-surface , border-default — not raw hex values Ensure sufficient contrast (4.5:1 for normal text, 3:1 for large text) Don't rely solely on color to convey information (use icons, text, or patterns too) Accessibility (WCAG 2.1 AA) Every component must meet these standards: Keyboard Navigation // Every interactive element must be keyboard accessible < button onClick = { handleClick }

Click me </ button

// ✓ Focusable by default < div onClick = { handleClick }

Click me </ div

// ✗ Not focusable < div role = " button " tabIndex = { 0 } onClick = { handleClick } // ✓ But prefer

返回排行榜