Agent-skills-standard react-native-performance
Optimize React Native rendering for smooth 60fps mobile experiences. Use when optimizing React Native app performance, reducing re-renders, or fixing frame drops. (triggers: **/*.tsx, **/*.ts, FlatList, memo, useMemo, useCallback, performance, optimization)
install
source · Clone the upstream repo
git clone https://github.com/HoangNguyen0403/agent-skills-standard
Claude Code · Install into ~/.claude/skills/
T=$(mktemp -d) && git clone --depth=1 https://github.com/HoangNguyen0403/agent-skills-standard "$T" && mkdir -p ~/.claude/skills && cp -r "$T/skills/react-native/react-native-performance" ~/.claude/skills/hoangnguyen0403-agent-skills-standard-react-native-performance && rm -rf "$T"
manifest:
skills/react-native/react-native-performance/SKILL.mdsource content
React Native Performance
Priority: P0 (CRITICAL)
Tune FlatList for 60fps
: Reduce to 5-10 for memory-heavy lists (default 21).windowSize
should cover first viewport.initialNumToRender
: Provide for fixed-height items. Skips runtime measurement.getItemLayout
: Enable for Android (default true) to offload clipped items.removeClippedSubviews
: Limit to 5-10 items per frame to prevent JS thread blockage.maxToRenderPerBatch
: Use stable unique IDs, never array index.keyExtractor
See optimization guide for FlatList configuration examples with
getItemLayout, windowSize, and memoization patterns.
Accelerate Core Rendering
- ** Engine**: Ensure Hermes engine enabled (default in 0.7x). Verify via
.global.HermesInternal - Animations: Use Native Driver (
) or Reanimated 3 for GPU-accelerated 60fps animations.useNativeDriver: true - Re-renders: Use
andReact.memo
for expensive props. Profile via Flipper (React DevTools) for flamegraphs.useMemo - Network: Batch API calls. Use React Query/Zustand to prevent unnecessary screen refreshes.
- Images: Use
for caching and priority. Avoid large PNGs; use WebP.react-native-fast-image
Reduce Bundle and Startup Time
- Hermes: Enable for faster startup (default in RN 0.70+).
- Tree Shaking: Remove unused imports.
- ProGuard/R8: Enable code shrinking on Android.
- Lazy Screens: Use
prop for stack screens (enabled by default).lazy
Anti-Patterns
- No ScrollView for Large Lists: Use FlatList.
- No Inline Styles: Use
(optimized).StyleSheet.create - No console.log in Production: Strip with babel plugin.
References
See references/optimization-guide.md for FlatList configuration, memoization rules, and bundle analysis.