Sign Up for Free

RunKit +

Try any Node.js package right in your browser

This is a playground to test code. It runs a full Node.js environment and already has all of npm’s 400,000 packages pre-installed, including react-addons-pure-render-mixin with all npm packages installed. Try it out:

var reactAddonsPureRenderMixin = require("react-addons-pure-render-mixin")

This service is provided by RunKit and is not affiliated with npm, Inc or the package authors.

react-addons-pure-render-mixin v15.6.2


Note: This is a legacy React addon, and is no longer maintained.

We don't encourage using it in new code, but it exists for backwards compatibility.
The recommended migration path is to use React.PureComponent instead.


import PureRenderMixin from 'react-addons-pure-render-mixin'; // ES6
var PureRenderMixin = require('react-addons-pure-render-mixin'); // ES5 with npm

If you prefer a <script> tag, you can get it from React.addons.PureRenderMixin with:

<!-- development version -->
<script src=""></script>

<!-- production version -->
<script src=""></script>

In this case, make sure to put the <script> tag after React.


If your React component's render function renders the same result given the same props and state, you can use this mixin for a performance boost in some cases.


const createReactClass = require('create-react-class');

  mixins: [PureRenderMixin],

  render: function() {
    return <div className={this.props.className}>foo</div>;

Under the hood, the mixin implements shouldComponentUpdate, in which it compares the current props and state with the next ones and returns false if the equalities pass.


This only shallowly compares the objects. If these contain complex data structures, it may produce false-negatives for deeper differences. Only mix into components which have simple props and state, or use forceUpdate() when you know deep data structures have changed. Or, consider using immutable objects to facilitate fast comparisons of nested data.

Furthermore, shouldComponentUpdate skips updates for the whole component subtree. Make sure all the children components are also "pure".

RunKit is a free, in-browser JavaScript dev environment for prototyping Node.js code, with every npm package installed. Sign up to share your code.
Sign Up for Free