You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

182 lines
5.6 KiB

---
id: perf
title: Performance Tools
permalink: docs/perf.html
layout: docs
category: Add-Ons
prev: create-fragment.html
next: test-utils.html
---
**Importing**
```javascript
import Perf from 'react-addons-perf' // ES6
var Perf = require('react-addons-perf') // ES5 with npm
var Perf = React.addons.Perf; // ES5 with react-with-addons.js
// Usually importing Perf in ES6 with a module bundler
// doesn't make Perf available as global and throws a
// ReferenceError so create a global
window.Perf = Perf;
```
## Overview
React is usually quite fast out of the box. However, in situations where you need to squeeze every ounce of performance out of your app, it provides a [shouldComponentUpdate()](/react/docs/react-component.html#shouldcomponentupdate) hook where you can add optimization hints to React's diff algorithm.
In addition to giving you an overview of your app's overall performance, `Perf` is a profiling tool that tells you exactly where you need to put these hooks.
See these articles for an introduction to React performance tooling:
- ["How to Benchmark React Components"](https://medium.com/code-life/how-to-benchmark-react-components-the-quick-and-dirty-guide-f595baf1014c)
- ["Performance Engineering with React"](http://benchling.engineering/performance-engineering-with-react/)
- ["A Deep Dive into React Perf Debugging"](http://benchling.engineering/deep-dive-react-perf-debugging/)
### Development vs. Production Builds
If you're benchmarking or seeing performance problems in your React apps, make sure you're testing with the [minified production build](/react/downloads.html). The development build includes extra warnings that are helpful when building your apps, but it is slower due to the extra bookkeeping it does.
However, the perf tools described on this page only work when using the development build of React. Therefore, the profiler only serves to indicate the _relatively_ expensive parts of your app.
### Using Perf
The `Perf` object can be used with React in development mode only. You should not include this bundle when building your app for production.
#### Getting Measurements
- [`start()`](#start)
- [`stop()`](#stop)
- [`getLastMeasurements()`](#getlastmeasurements)
#### Printing Results
The following methods use the measurements returned by [`Perf.getLastMeasurements()`](#getlastmeasurements) to pretty-print the result.
- [`printInclusive()`](#printinclusive)
- [`printExclusive()`](#printexclusive)
- [`printWasted()`](#printwasted)
- [`printOperations()`](#printoperations)
- [`printDOM()`](#printdom)
* * *
## Example Usage
We will take simple example of a form which can be used to submit comments and then listing all comments. The example code is [available on GitHub](https://github.com/dhyey35/react-example-for-performance/blob/master/public/scripts/example.js).
```javascript
import { Component } from 'react'
import Perf from 'react-addons-perf'
const Comment = (props) => (
<div className="comment">
<h2 className="commentAuthor">
{props.author}
</h2>
<span>{props.children.toString()}</span>
</div>
)
//code...
ReactDOM.render(
<CommentBox />,
document.getElementById('content')
);
```
Open the developer console in the browser and type `Perf.start()`. Then perform the action you want to monitor, like submitting a form. Finally, type `Perf.stop()` and `Perf.getLastMeasurements()` to get the measurements. See the Reference below for more methods.
![](/react/img/docs/addons-perf.png)
* * *
## Reference
### `start()`
### `stop()`
```javascript
Perf.start()
// ...
Perf.stop()
```
Start/stop the measurement. The React operations in-between are recorded for analyses below. Operations that took an insignificant amount of time are ignored.
After stopping, you will need [`Perf.getLastMeasurements()`](#getlastmeasurements) to get the measurements.
* * *
### `getLastMeasurements()`
```javascript
Perf.getLastMeasurements()
```
Get the opaque data structure describing measurements from the last start-stop session. You can save it and pass it to the other print methods in [`Perf`](#printing-results) to analyze past measurements.
> Note
>
> Don't rely on the exact format of the return value because it may change in minor releases. We will update the documentation if the return value format becomes a supported part of the public API.
* * *
### `printInclusive()`
```javascript
Perf.printInclusive(measurements)
```
Prints the overall time taken. If no argument's passed, defaults to all the measurements from the last recording. This prints a nicely formatted table in the console, like so:
![](/react/img/docs/perf-inclusive.png)
* * *
### `printExclusive()`
```javascript
Perf.printExclusive(measurements)
```
"Exclusive" times don't include the times taken to mount the components: processing props, calling `componentWillMount` and `componentDidMount`, etc.
![](/react/img/docs/perf-exclusive.png)
* * *
### `printWasted()`
```javascript
Perf.printWasted(measurements)
```
**The most useful part of the profiler**.
"Wasted" time is spent on components that didn't actually render anything, e.g. the render stayed the same, so the DOM wasn't touched.
![](/react/img/docs/perf-wasted.png)
* * *
### `printOperations()`
```javascript
Perf.printOperations(measurements)
```
Prints the underlying DOM manipulations, e.g. "set innerHTML" and "remove".
![](/react/img/docs/perf-dom.png)
* * *
### `printDOM()`
```javascript
Perf.printDOM(measurements)
```
This method has been renamed to [`printOperations()`](#printoperations). Currently `printDOM()` still exists as an alias but it prints a deprecation warning and will eventually be removed.