react-native icon indicating copy to clipboard operation
react-native copied to clipboard

Fast Refresh not compatible with React Hooks call chain

Open NiuGuohui opened this issue 1 month ago • 6 comments

Description

During the development process, when adding or deleting hooks, the devServer was not compatible with the destructive modifications to the hook chain. Instead, it directly caused React Native to report an error, making the application unable to run anymore and requiring a restart.

Android Platform

React has detected a change in the order of Hooks called by App. This will lead to bugs and errors if not fixed. For more information, read the Rules of Hooks: https://react.dev/link/rules-of-hooks

   Previous render            Next render
   ------------------------------------------------------
1. useSyncExternalStore       useSyncExternalStore
2. undefined                  useState
   ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
 Error Stack:
    at App (App.tsx:18:30)
Error: Rendered more hooks than during the previous render.
    at updateWorkInProgressHook (ReactFabric-dev.js:4039:22)
    at updateReducer (ReactFabric-dev.js:4158:42)
    at useState (ReactFabric-dev.js:15273:31)
    at anonymous (react.development.js:1222:42)
    at App (App.tsx:18:30)

Steps to reproduce

  • clone this repo and run dev
  • open App.tsx
  • Comment out line 18. (code: const breakChain = useState(null);)
  • save changes
  • app was report an error
  • You can try to comment this line of code repeatedly to repeat the bug

React Native Version

0.82.1

Affected Platforms

Runtime - Android

Output of npx @react-native-community/cli info

System:
  OS: macOS 26.0.1
  CPU: (10) arm64 Apple M1 Max
  Memory: 2.05 GB / 64.00 GB
  Shell:
    version: "5.9"
    path: /bin/zsh
Binaries:
  Node:
    version: 22.21.1
    path: /Users/ollie/.nvm/versions/node/v22.21.1/bin/node
  Yarn:
    version: 1.22.22
    path: /Users/ollie/.nvm/versions/node/v22.21.1/bin/yarn
  npm:
    version: 10.9.4
    path: /Users/ollie/.nvm/versions/node/v22.21.1/bin/npm
  Watchman: Not Found
Managers:
  CocoaPods: Not Found
SDKs:
  iOS SDK:
    Platforms:
      - DriverKit 25.0
      - iOS 26.0
      - macOS 26.0
      - tvOS 26.0
      - visionOS 26.0
      - watchOS 26.0
  Android SDK: Not Found
IDEs:
  Android Studio: 2025.1 AI-251.27812.49.2514.14217341
  Xcode:
    version: 26.0.1/17A400
    path: /usr/bin/xcodebuild
Languages:
  Java:
    version: 17.0.17
    path: /Users/ollie/.jenv/shims/javac
  Ruby:
    version: 2.6.10
    path: /usr/bin/ruby
npmPackages:
  "@react-native-community/cli":
    installed: 20.0.0
    wanted: 20.0.0
  react:
    installed: 19.1.1
    wanted: 19.1.1
  react-native:
    installed: 0.82.1
    wanted: 0.82.1
  react-native-macos: Not Found
npmGlobalPackages:
  "*react-native*": Not Found
Android:
  hermesEnabled: true
  newArchEnabled: true
iOS:
  hermesEnabled: Not found
  newArchEnabled: false

Stacktrace or Logs

React has detected a change in the order of Hooks called by App. This will lead to bugs and errors if not fixed. For more information, read the Rules of Hooks: https://react.dev/link/rules-of-hooks

   Previous render            Next render
   ------------------------------------------------------
1. useSyncExternalStore       useSyncExternalStore
2. undefined                  useState
   ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
 Error Stack:
    at App (App.tsx:18:30)

MANDATORY Reproducer

https://github.com/NiuGuohui/ReactNativeFastRefreshBug

Screenshots and Videos

No response

NiuGuohui avatar Nov 12 '25 07:11 NiuGuohui

Could someone please answer this question?

NiuGuohui avatar Nov 19 '25 02:11 NiuGuohui

Hi @NiuGuohui , I was able to reproduce a hooks order mismatch, but in my run the error reported “Rendered fewer hooks than expected” instead of “Rendered more hooks than during the previous render” as you mentioned — it still indicates a hooks order conflict right?

Thotaharshavardhani avatar Nov 24 '25 12:11 Thotaharshavardhani

@Thotaharshavardhani Yes, essentially, both of these error reports are caused by the destruction of the component's hook chain after React hot updates.

NiuGuohui avatar Nov 25 '25 01:11 NiuGuohui

@devanshsaini11 were you able to reproduce locally?

cortinico avatar Nov 25 '25 18:11 cortinico

Hi @cortinico @Thotaharshavardhani was able to reproduce this locally

devanshsaini11 avatar Nov 26 '25 09:11 devanshsaini11

@cortinico Is this issue expected to be fixed in version 0.83? This issue greatly affects the development experience.

NiuGuohui avatar Dec 03 '25 01:12 NiuGuohui