react-native-dev

|

INSTALLATION
npx skills add https://github.com/minimax-ai/skills --skill react-native-dev
Run in your project or agent environment. Adjust flags if your CLI version differs.

SKILL.md

$28

Quick Reference

Component Preferences

Purpose

Use

Instead of

Lists

FlashList (@shopify/flash-list) + memo items

FlatList (no view recycling)

Images

expo-image

RN <Image> (no cache, no WebP)

Press

Pressable

TouchableOpacity (legacy)

Audio

expo-audio

expo-av (deprecated)

Video

expo-video

expo-av (deprecated)

Animations

Reanimated 3

RN Animated API (limited)

Gestures

Gesture Handler

PanResponder (legacy)

Platform check

process.env.EXPO_OS

Platform.OS

Context

React.use()

React.useContext() (React 18)

Safe area scroll

contentInsetAdjustmentBehavior="automatic"

<SafeAreaView>

SF Symbols

expo-image with source="sf:name"

expo-symbols

Scaling Up

Situation

Consider

Long lists with scroll jank

Virtualized list libraries (e.g. FlashList)

Want Tailwind-style classes

NativeWind v4

High-frequency storage reads

Sync-based storage (e.g. MMKV)

New project with Expo

Expo Router over bare React Navigation

State Management

State Type

Solution

Local UI state

useState / useReducer

Shared app state

Zustand or Jotai

Server / async data

React Query

Form state

React Hook Form + Zod

Performance Priorities

Priority

Issue

Fix

CRITICAL

Long list jank

FlashList + memoized items

CRITICAL

Large bundle

Avoid barrel imports, enable R8

HIGH

Too many re-renders

Zustand selectors, React Compiler

HIGH

Slow startup

Disable bundle compression, native nav

MEDIUM

Animation drops

Only animate transform/opacity

New Project Init

# 1. Create project

npx create-expo-app@latest my-app --template blank-typescript

cd my-app

# 2. Install Expo Router + core deps

npx expo install expo-router react-native-safe-area-context react-native-screens

# 3. (Optional) Common extras

npx expo install expo-image react-native-reanimated react-native-gesture-handler

Then configure:

  • Set entry point in package.json: "main": "expo-router/entry"
  • Add scheme in app.json: "scheme": "my-app"
  • Delete App.tsx and index.ts
  • Create app/_layout.tsx as root Stack layout
  • Create app/(tabs)/_layout.tsx for tab navigation

For web support, also install: npx expo install react-native-web react-dom @expo/metro-runtime

Core Principles

Consult references before writing: when implementing navigation, lists, networking, or project setup, read the matching reference file above for patterns and pitfalls.

Try Expo Go first (npx expo start). Custom builds (eas build) only needed when using local Expo modules, Apple targets, or third-party native modules not in Expo Go.

Conditional rendering: use {count > 0 &#x26;&#x26; <Text />} not {count &#x26;&#x26; <Text />} (renders "0").

Animation rule: only animate transform and opacity — GPU-composited, no layout thrash.

Imports: always import directly from source, not barrel files — avoids bundle bloat.

Lists and images: before using FlatList or RN Image, check the Component Preferences table above — FlashList and expo-image are almost always the right choice.

Route files: always use kebab-case, never co-locate components/types/utils in app/.

Checklist

New Project Setup

  • tsconfig.json path aliases configured
  • EXPO_PUBLIC_API_URL env var set per environment
  • Root layout has GestureHandlerRootView (if using gestures)
  • contentInsetAdjustmentBehavior="automatic" on all scroll views
  • FlashList instead of FlatList for lists > 20 items

Before Shipping

  • Profile in --profile mode, fix frames > 16ms
  • Bundle analyzed (source-map-explorer), no barrel imports
  • R8 enabled for Android
  • Unit + component tests for critical paths
  • E2E flows for login, core feature, checkout

Flutter development → see flutter-dev skill.

iOS native (UIKit/SwiftUI) → see ios-application-dev skill.

Android native (Kotlin/Compose) → see android-native-dev skill.

React Native is a trademark of Meta Platforms, Inc. Expo is a trademark of 650 Industries, Inc. All other product names are trademarks of their respective owners.

BrowserAct

Let your agent run on any real-world website

Bypass CAPTCHA & anti-bot for free. Start local, scale to cloud.

Explore BrowserAct Skills →

Stop writing automation&scrapers

Install the CLI. Run your first Skill in 30 seconds. Scale when you're ready.

Start free
free · no credit card