react-devtools
    DefinitelyTyped icon, indicating that this package has TypeScript declarations provided by the separate @types/react-devtools package

    4.23.0 • Public • Published

    react-devtools

    React DevTools is available as a built-in extension for Chrome and Firefox browsers. This package enables you to debug a React app elsewhere (e.g. a mobile browser, an embedded webview, Safari, inside an iframe).

    It works both with React DOM and React Native.

    React DevTools screenshot

    Installation

    Install the react-devtools package. Because this is a development tool, a global install is often the most convenient:

    # Yarn
    yarn global add react-devtools
    
    # NPM
    npm install -g react-devtools

    If you prefer to avoid global installations, you can add react-devtools as a project dependency. With Yarn, you can do this by running:

    yarn add --dev react-devtools

    With NPM you can just use NPX:

    npx react-devtools

    Usage with React Native

    Run react-devtools from the terminal to launch the standalone DevTools app:

    react-devtools

    If you're not in a simulator then you also need to run the following in a command prompt:

    adb reverse tcp:8097 tcp:8097

    If you're using React Native 0.43 or higher, it should connect to your simulator within a few seconds.

    Integration with React Native Inspector

    You can open 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:

    React Native Inspector

    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:

    React DevTools Inspector Integration

    You can choose "Hide Inspector" in the same menu to exit this mode.

    Inspecting Component Instances

    When debugging JavaScript in Chrome, you can inspect the props and state of the React components in the browser console.

    First, follow the instructions for debugging in Chrome to open the Chrome console.

    Make sure that the dropdown in the top left corner of the Chrome console says debuggerWorker.js. This step is essential.

    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.

    React DevTools Chrome Console Integration

    Usage with React DOM

    The standalone shell can also be useful with React DOM (e.g. to debug apps in Safari or inside of an iframe).

    Run react-devtools from the terminal to launch the standalone DevTools app:

    react-devtools

    Add <script src="http://localhost:8097"></script> as the very first <script> tag in the <head> of your page when developing:

    <!doctype html>
    <html lang="en">
      <head>
        <script src="http://localhost:8097"></script>

    This will ensure the developer tools are connected. Don’t forget to remove it before deploying to production!

    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.

    Advanced

    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.

    FAQ

    The React Tab Doesn't Show Up

    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:

    Allow access to file URLs

    Or you could develop with a local HTTP server like serve.

    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 or by inspecting Facebook.

    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.

    If your app is inside an iframe, a Chrome extension, React Native, or in another unusual environment, try the standalone version instead. Chrome apps are currently not inspectable.

    If you still have issues please report them. Don't forget to specify your OS, browser version, extension version, and the exact instructions to reproduce the issue with a screenshot.

    Local development

    The standalone DevTools app can be built and tested from source following the instructions below.

    Prerequisite steps

    DevTools depends on local versions of several NPM packages1 also in this workspace. You'll need to either build or download those packages first.

    1 Note that at this time, an experimental build is required because DevTools depends on the createRoot API.

    Build from source

    To build dependencies from source, run the following command from the root of the repository:

    yarn build-for-devtools

    Download from CI

    To use the latest build from CI, run the following command from the root of the repository:

    ./scripts/release/download-experimental-build.js

    Build steps

    You can test the standalone DevTools by running the following:

    • First, complete the prerequisite steps above! If you don't do it, none of the steps below will work.
    • Then, run yarn start:backend and yarn start:standalone in ../react-devtools-core
    • Run yarn start in this folder
    • Refresh the app after it has recompiled a change
    • For React Native, copy react-devtools-core to its node_modules to test your changes.

    Keywords

    none

    Install

    npm i react-devtools

    DownloadsWeekly Downloads

    63,941

    Version

    4.23.0

    License

    MIT

    Unpacked Size

    23.2 kB

    Total Files

    7

    Last publish

    Collaborators

    • sebmarkbage
    • gaearon
    • acdlite
    • brianvaughn
    • jstejada
    • sophiebits
    • lunaruan