1. # `react-devtools`
    
  2. 
    
  3. This package can be used to debug non-browser-based React applications (e.g. React Native, mobile browser or embedded webview, Safari).
    
  4. 
    
  5. ![React DevTools screenshot](https://user-images.githubusercontent.com/29597/63811956-bdd9b580-c8dd-11e9-8962-c568e475c425.png)
    
  6. 
    
  7. ## Installation
    
  8. Install the `react-devtools` package. Because this is a development tool, a global install is often the most convenient:
    
  9. ```sh
    
  10. # Yarn
    
  11. yarn global add react-devtools
    
  12. 
    
  13. # NPM
    
  14. npm install -g react-devtools
    
  15. ```
    
  16. 
    
  17. If you prefer to avoid global installations, you can add `react-devtools` as a project dependency. With Yarn, you can do this by running:
    
  18. ```sh
    
  19. yarn add --dev react-devtools
    
  20. ```
    
  21. 
    
  22. With NPM you can just use [NPX](https://www.npmjs.com/package/npx):
    
  23. ```sh
    
  24. npx react-devtools
    
  25. ```
    
  26. 
    
  27. ## Usage with React Native
    
  28. Run `react-devtools` from the terminal to launch the standalone DevTools app:
    
  29. ```sh
    
  30. react-devtools
    
  31. ```
    
  32. 
    
  33. If you're not using a local simulator, you'll also need to forward ports used by React DevTools:
    
  34. ```sh
    
  35. adb reverse tcp:8097 tcp:8097
    
  36. ```
    
  37. 
    
  38. If you're using React Native 0.43 or higher, it should connect to your simulator within a few seconds. (If this doesn't happen automatically, try reloading the React Native app.)
    
  39. 
    
  40. ### Integration with React Native Inspector
    
  41. 
    
  42. You can open the [in-app developer menu](https://reactnative.dev/docs/debugging#accessing-the-in-app-developer-menu) and choose "Show Inspector". It will bring up an overlay that lets you tap on any UI element and see information about it:
    
  43. 
    
  44. ![React Native Inspector](https://i.imgur.com/ReFhREb.gif)
    
  45. 
    
  46. However, when `react-devtools` is running, Inspector will enter a special collapsed mode, and instead use the DevTools as primary UI. In this mode, clicking on something in the simulator will bring up the relevant components in the DevTools:
    
  47. 
    
  48. ![React DevTools Inspector Integration](https://user-images.githubusercontent.com/29597/63811958-be724c00-c8dd-11e9-8587-37357334a0e1.gif)
    
  49. 
    
  50. 
    
  51. You can choose "Hide Inspector" in the same menu to exit this mode.
    
  52. 
    
  53. ### Inspecting Component Instances
    
  54. 
    
  55. When debugging JavaScript in Chrome, you can inspect the props and state of the React components in the browser console.
    
  56. 
    
  57. First, follow the [instructions for debugging in Chrome](https://reactnative.dev/docs/debugging#chrome-developer-tools) to open the Chrome console.
    
  58. 
    
  59. Make sure that the dropdown in the top left corner of the Chrome console says `debuggerWorker.js`. **This step is essential.**
    
  60. 
    
  61. Then select a React component in React DevTools. There is a search box at the top that helps you find one by name. As soon as you select it, it will be available as `$r` in the Chrome console, letting you inspect its props, state, and instance properties.
    
  62. 
    
  63. ![React DevTools Chrome Console Integration](https://user-images.githubusercontent.com/29597/63811957-be724c00-c8dd-11e9-9d1d-8eba440ef948.gif)
    
  64. 
    
  65. 
    
  66. ## Usage with React DOM
    
  67. 
    
  68. The standalone shell can also be useful with React DOM (e.g. to debug apps in Safari or inside of an iframe).
    
  69. 
    
  70. Run `react-devtools` from the terminal to launch the standalone DevTools app:
    
  71. ```sh
    
  72. react-devtools
    
  73. ```
    
  74. 
    
  75. Add `<script src="http://localhost:8097"></script>` as the very first `<script>` tag in the `<head>` of your page when developing:
    
  76. 
    
  77. ```html
    
  78. <!doctype html>
    
  79. <html lang="en">
    
  80.   <head>
    
  81.     <script src="http://localhost:8097"></script>
    
  82. ```
    
  83. 
    
  84. This will ensure the developer tools are connected. **Don’t forget to remove it before deploying to production!**
    
  85. 
    
  86. >If you install `react-devtools` as a project dependency, you may also replace the `<script>` suggested above with a JavaScript import (`import 'react-devtools'`). It is important that this import comes before any other imports in your app (especially before `react-dom`). Make sure to remove the import before deploying to production, as it carries a large DevTools client with it. If you use Webpack and have control over its configuration, you could alternatively add `'react-devtools'` as the first item in the `entry` array of the development-only configuration, and then you wouldn’t need to deal either with `<script>` tags or `import` statements.
    
  87. 
    
  88. ## Advanced
    
  89. 
    
  90. By default DevTools listen to port `8097` on `localhost`. If you need to customize host, port, or other settings, see the `react-devtools-core` package instead.
    
  91. 
    
  92. ## FAQ
    
  93. 
    
  94. ### The React Tab Doesn't Show Up
    
  95. 
    
  96. **If you are running your app from a local `file://` URL**, don't forget to check "Allow access to file URLs" on the Chrome Extensions settings page. You can find it by opening Settings > Extensions:
    
  97. 
    
  98. ![Allow access to file URLs](https://user-images.githubusercontent.com/29597/64646784-95b58080-d3cc-11e9-943d-02474683398a.png)
    
  99. 
    
  100. Or you could develop with a local HTTP server like [`serve`](https://www.npmjs.com/package/serve).
    
  101. 
    
  102. **The React tab won't show up if the site doesn't use React**, or if React can't communicate with the devtools. When the page loads, the devtools sets a global named `__REACT_DEVTOOLS_GLOBAL_HOOK__`, then React communicates with that hook during initialization. You can test this on the [React website](https://reactjs.org/) or by inspecting [Facebook](https://www.facebook.com/).
    
  103. 
    
  104. **If your app is inside of CodePen**, make sure you are registered. Then press Fork (if it's not your pen), and then choose Change View > Debug. The Debug view is inspectable with DevTools because it doesn't use an iframe.
    
  105. 
    
  106. **If your app is inside an iframe, a Chrome extension, React Native, or in another unusual environment**, try [the standalone version instead](https://github.com/facebook/react/tree/main/packages/react-devtools). Chrome apps are currently not inspectable.
    
  107. 
    
  108. **If your Components tab is empty, refer to "The React tab shows no components" section below**.
    
  109. 
    
  110. **If you still have issues** please [report them](https://github.com/facebook/react/issues/new?labels=Component:%20Developer%20Tools). Don't forget to specify your OS, browser version, extension version, and the exact instructions to reproduce the issue with a screenshot.
    
  111. 
    
  112. ### The React tab shows no components
    
  113. 
    
  114. #### The Issue with Chrome v101 and earlier
    
  115. As we migrate to a Chrome Extension Manifest V3, we start to use a new method to hook the DevTools with the inspected page. This new method is more secure, but relies on a new API that's only supported in Chrome v102+. For Chrome v101 or earlier, we use a fallback method, which can cause malfunctions (e.g. failure to load React Elements in the Components tab) if the JS resources on your page is loaded from cache. Please upgrade to Chrome v102+ to avoid this issue.
    
  116. 
    
  117. #### Service Worker malfunction
    
  118. Go to chrome://extensions. If you see "service worker (inactive)" in the React Developer Tools extension, try disabling and re-enabling the extension. This will restart the service worker. Then go to the page you want to inspect, close the DevTools, and reload the page. Open the DevTools again and the React components tab should be working.
    
  119. 
    
  120. ## Local development
    
  121. The standalone DevTools app can be built and tested from source following the instructions below.
    
  122. 
    
  123. ### Prerequisite steps
    
  124. DevTools depends on local versions of several NPM packages<sup>1</sup> also in this workspace. You'll need to either build or download those packages first.
    
  125. 
    
  126. <sup>1</sup> Note that at this time, an _experimental_ build is required because DevTools depends on the `createRoot` API.
    
  127. 
    
  128. #### Build from source
    
  129. To build dependencies from source, run the following command from the root of the repository:
    
  130. ```sh
    
  131. yarn build-for-devtools
    
  132. ```
    
  133. #### Download from CI
    
  134. To use the latest build from CI, run the following command from the root of the repository:
    
  135. ```sh
    
  136. ./scripts/release/download-experimental-build.js
    
  137. ```
    
  138. ### Build steps
    
  139. You can test the standalone DevTools by running the following:
    
  140. 
    
  141. * **First, complete the prerequisite steps above! If you don't do it, none of the steps below will work.**
    
  142. * Then, run `yarn start:backend` and `yarn start:standalone` in `packages/react-devtools-core`
    
  143. * Run `yarn start` in `packages/react-devtools`
    
  144. * Refresh the app after it has recompiled a change
    
  145. * For React Native, copy `react-devtools-core` to its `node_modules` to test your changes.