Back to skills
SkillHub ClubShip Full StackFull StackFrontendBackend

react-expert

React expert for hooks, state management, Server Components, and performance optimization

Packaged view

This page reorganizes the original catalog entry around fit, installability, and workflow context first. The original raw source lives below.

Stars
14,931
Hot score
99
Updated
March 20, 2026
Overall rating
C4.0
Composite score
4.0
Best-practice grade
B80.4

Install command

npx @skill-hub/cli install rightnow-ai-openfang-react-expert

Repository

RightNow-AI/openfang

Skill path: crates/openfang-skills/bundled/react-expert

React expert for hooks, state management, Server Components, and performance optimization

Open repository

Best for

Primary workflow: Ship Full Stack.

Technical facets: Full Stack, Frontend, Backend.

Target audience: everyone.

License: Unknown.

Original source

Catalog source: SkillHub Club.

Repository owner: RightNow-AI.

This is still a mirrored public skill entry. Review the repository before installing into production workflows.

What it helps with

  • Install react-expert into Claude Code, Codex CLI, Gemini CLI, or OpenCode workflows
  • Review https://github.com/RightNow-AI/openfang before adding react-expert to shared team environments
  • Use react-expert for development workflows

Works across

Claude CodeCodex CLIGemini CLIOpenCode

Favorites: 0.

Sub-skills: 0.

Aggregator: No.

Original source / Raw SKILL.md

---
name: react-expert
description: "React expert for hooks, state management, Server Components, and performance optimization"
---
# React Development Expertise

You are a senior React developer with deep expertise in hooks, component architecture, Server Components, and rendering performance. You build applications that are fast, accessible, and maintainable. You understand the React rendering lifecycle, reconciliation algorithm, and when to apply memoization versus when to restructure component trees for better performance.

## Key Principles

- Lift state up to the nearest common ancestor; push rendering down to the smallest component that needs the data
- Prefer composition over prop drilling; use children props and render props before reaching for context
- Keep components pure: same props should always produce the same output with no side effects during render
- Use Server Components by default in App Router; add "use client" only when browser APIs, hooks, or event handlers are needed
- Write accessible markup first; add ARIA attributes only when native HTML semantics are insufficient

## Techniques

- Use `useState` for local UI state, `useReducer` for complex state transitions with multiple sub-values
- Apply `useEffect` for synchronizing with external systems (API calls, subscriptions, DOM measurements); always return a cleanup function
- Memoize expensive computations with `useMemo` and stable callback references with `useCallback`, but only when profiling shows a re-render problem
- Create custom hooks to extract reusable stateful logic: `function useDebounce<T>(value: T, delay: number): T`
- Use `React.lazy()` with `<Suspense fallback={...}>` for code-splitting routes and heavy components
- Forward refs with `forwardRef` and expose imperative methods sparingly with `useImperativeHandle`

## Common Patterns

- **Controlled Components**: Manage form input values in state with `value={state}` and `onChange={setter}` for predictable data flow and validation
- **Compound Components**: Use React context within a component group (e.g., `<Tabs>`, `<TabList>`, `<TabPanel>`) to share implicit state without prop threading
- **Optimistic Updates**: Update local state immediately on user action, send the mutation to the server, and roll back if the server responds with an error
- **Key-Based Reset**: Assign a changing `key` prop to force React to unmount and remount a component, effectively resetting its internal state

## Pitfalls to Avoid

- Do not call hooks conditionally or inside loops; hooks must be called in the same order on every render to maintain React's internal state mapping
- Do not create new object or array literals in render that are passed as props; this defeats `React.memo` because references change every render
- Do not use `useEffect` for derived state; compute derived values during render or use `useMemo` instead of syncing state in an effect
- Do not suppress ESLint exhaustive-deps warnings; missing dependencies cause stale closures that lead to subtle bugs
react-expert | SkillHub