From 1d82c291fed748504c7d0d83d36db382c476fe8c Mon Sep 17 00:00:00 2001 From: Brian Vaughn Date: Tue, 5 Jun 2018 14:46:22 -0400 Subject: [PATCH] Fix CodeSandbox demo to show the specific problem we are trying to illustrate --- .../derived-state-anti-pattern.js | 10 +++++++--- 1 file changed, 7 insertions(+), 3 deletions(-) diff --git a/examples/when-to-use-derived-state/derived-state-anti-pattern.js b/examples/when-to-use-derived-state/derived-state-anti-pattern.js index 386ebb6a..ad1e099a 100644 --- a/examples/when-to-use-derived-state/derived-state-anti-pattern.js +++ b/examples/when-to-use-derived-state/derived-state-anti-pattern.js @@ -5,17 +5,21 @@ import {render} from 'react-dom'; // Don't copy this approach! class ExampleInput extends PureComponent { state = { + prevProps: this.props, text: this.props.text, }; // This lifecycle will be re-run any time the component is rendered, - // Even if props (or props.text) have not changed. + // Even if props.text has not changed. // For this reason, it should not update state in the way shown below! static getDerivedStateFromProps(props, state) { - if (props.text) { + if (props !== state.prevProps) { // This return would override state, // Erasing anything the user typed since the last render. - return {text: props.text}; + return { + prevProps: props, + text: props.text, + }; } return null; }