Raw File
devtools.md
# DevTools Overview

Angular DevTools is a browser extension that provides debugging and profiling capabilities for Angular applications.
Angular DevTools supports Angular v12 and later when compiled with the [optimization configuration option](guide/workspace-config#optimization-configuration) disabled (<code>{optimization:false}</code>). 

<div class="video-container">

<iframe allow="accelerometer; encrypted-media; gyroscope; picture-in-picture" title="DevTools Overview" allowfullscreen frameborder="0" src="https://www.youtube.com/embed/bavWOHZM6zE"></iframe>

</div>

You can find Angular DevTools in the [Chrome Web Store](https://chrome.google.com/webstore/detail/angular-developer-tools/ienfalfjdbdpebioblfackkekamfmbnh) and in [Firefox Addons](https://addons.mozilla.org/en-GB/firefox/addon/angular-devtools/).

After installing Angular DevTools, find the extension under the Angular tab in your browser DevTools.

<div class="lightbox">

<img alt="devtools" src="generated/images/guide/devtools/devtools.png">

</div>

When you open the extension, you'll see two additional tabs:

| Tabs                      | Details |
|:---                       |:---     |
| [Components](#components) | Lets you explore the components and directives in your application and preview or edit their state.                    |
| [Profiler](#profiler)     | Lets you profile your application and understand what the performance bottleneck is during change detection execution. |

<div class="lightbox">

<img alt="devtools tabs" src="generated/images/guide/devtools/devtools-tabs.png">

</div>

In the top-right corner of Angular DevTools you'll find which version of Angular is running on the page as well as the latest commit hash for the extension.

## Bug reports

Report issues and feature requests on [GitHub](https://github.com/angular/angular/issues).

To report an issue with the Profiler, export the Profiler recording by clicking the **Save Profile** button, and then attaching that export as a file in the issue.

<div class="alert is-helpful">

Make sure that the Profiler recording does not contain any confidential information.

</div>

<a id="components"></a>

## Debug your application

The **Components** tab lets you explore the structure of your application.
You can visualize and inspect the component and directive instances and preview or modify their state.
In the next couple of sections we'll look into how to use this tab effectively to debug your application.

### Explore the application structure

<div class="lightbox">

<img alt="component-explorer" src="generated/images/guide/devtools/component-explorer.png">

</div>

In the preceding screenshot, you can see the component tree of an application.

The component tree displays a hierarchical relationship of the *components and directives* within your application.
When you select a component or a directive instance, Angular DevTools presents additional information about that instance.

### View properties

Click the individual components or directives in the component explorer to select them and preview their properties.
Angular DevTools displays their properties and metadata on the right-hand side of the component tree.

Navigate in the component tree using the mouse or the following keyboard shortcuts:

| Keyboard shortcut     | Details |
|:---                   |:---     |
| Up and down arrows    | Select the previous and next nodes |
| Left and right arrows | Collapse and expand a node         |

To look up a component or directive by name use the search box above the component tree.
To navigate to the next search match, press `Enter`.
To navigate to the previous search match, press `Shift + Enter`.

<div class="lightbox">

<img alt="search" src="generated/images/guide/devtools/search.png">

</div>

### Navigate to the host node

To go to the host element of a particular component or directive, find it in the component explorer and double-click it.
Browsers' DevTools opens the Elements tab in Chrome or the Inspector one in Firefox, and selects the associated DOM node.

### Navigate to source

For components, Angular DevTools also lets you navigate to the component definition in the source tab.
After you select a particular component, click the icon at the top-right of the properties view:

<div class="lightbox">

<img alt="navigate source" src="generated/images/guide/devtools/navigate-source.png">

</div>

### Update property value

Like browsers' DevTools, the properties view lets you edit the value of an input, output, or another property.
Right-click on the property value.
If edit functionality is available for this value type, you'll see a text input.
Type the new value and press `Enter`.

<div class="lightbox">

<img alt="update property" src="generated/images/guide/devtools/update-property.png">

</div>

### Access selected component or directive in console

As a shortcut in the console, Angular DevTools provides you access to instances of the recently selected components or directives.
Type `$ng0` to get a reference to the instance of the currently selected component or directive, and type `$ng1` for the previously selected instance.

<div class="lightbox">

<img alt="access console" src="generated/images/guide/devtools/access-console.png">

</div>

### Select a directive or component

Similar to browsers' DevTools, you can inspect the page to select a particular component or directive.
Click the ***Inspect element*** icon in the top left corner within Angular DevTools and hover over a DOM element on the page.
The extension recognizes the associated directives and/or components and lets you select the corresponding element in the Component tree.

<div class="lightbox">

<img alt="selecting dom node" src="generated/images/guide/devtools/inspect-element.png">

</div>

<a id="profiler"></a>

## Profile your application

The **Profiler** tab lets you preview the execution of Angular's change detection.

<div class="lightbox">

<img alt="profiler" src="generated/images/guide/devtools/profiler.png">

</div>

The Profiler lets you start profiling or import an existing profile.
To start profiling your application, hover over the circle in the top-left corner within the **Profiler** tab and click **Start recording**.

During profiling, Angular DevTools captures execution events, such as change detection and lifecycle hook execution.
To finish recording, click the circle again to **Stop recording**.

You can also import an existing recording.
Read more about this feature in the [Import recording](#) section.

### Understand your application's execution

In the following screenshot, find the default view of the Profiler after you complete recording.

<div class="lightbox">

<img alt="default profiler view" src="generated/images/guide/devtools/default-profiler-view.png">

</div>

Near the top of the view you can see a sequence of bars, each one of them symbolizing change detection cycles in your app.
The taller a bar is, the longer your application has spent in this cycle.
When you select a bar, DevTools renders a bar chart with all the components and directives that it captured during this cycle.

<div class="lightbox">

<img alt="profiler selected bar" src="generated/images/guide/devtools/profiler-selected-bar.png">

</div>

Earlier on the change detection timeline, you can find how much time Angular spent in this cycle.
Angular DevTools attempts to estimate the frame drop at this point to indicate when the execution of your application might impact the user experience.

Angular DevTools also indicates what triggered the change detection \(that is, the change detection's source\).

### Understand component execution

When you click on a bar, you'll find a detailed view about how much time your application spent in the particular directive or component:

<div class="lightbox">

<img alt="directive details" src="generated/images/guide/devtools/directive-details.png">

</div>

Figure shows the total time spent by NgforOf directive and which method was called in it.
It also shows the parent hierarchy of the directive selected.

### Hierarchical views

<div class="lightbox">

<img alt="flame graph view" src="generated/images/guide/devtools/flame-graph-view.png">

</div>

You can also preview the change detection execution in a flame graph-like view.
Each tile in the graph represents an element on the screen at a specific position in the render tree.

For example, if during one change detection cycle at a specific position in the component tree you had `ComponentA`, this component was removed and in its place Angular rendered `ComponentB`, you'll see both components at the same tile.

Each tile is colored depending on how much time Angular spent there.
DevTools determines the intensity of the color by the time spent relative to the tile where we've spent the most time in change detection.

When you click on a certain tile, you'll see details about it in the panel on the right.
Double-clicking the tile zooms it in so you can preview the nested children.

### Debug OnPush

To preview the components in which Angular did change detection, select the **Change detection** checkbox at the top, above the flame graph.

This view colors all the tiles in which Angular performed change detection in green, and the rest in gray:

<div class="lightbox">

<img alt="debugging onpush" src="generated/images/guide/devtools/debugging-onpush.png">

</div>

### Import recording

Click the **Save Profile** button at the top-left of a recorded profiling session to export it as a JSON file and save it to the disk.
Then, import the file in the initial view of the profiler by clicking the **Choose file** input:

<div class="lightbox">

<img alt="save profile" src="generated/images/guide/devtools/save-profile.png">

</div>

<!-- links -->

<!-- external links -->

<!-- end links -->

@reviewed 2022-02-28
back to top