From 60daa37dd56b61865f4774968b4ba643ca4e33cf Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Mateusz=20Burzy=C5=84ski?= Date: Fri, 15 Apr 2022 11:23:27 +0200 Subject: [PATCH] Recycle prevProps in simple memo based on the `shallowEqual` check --- packages/react-reconciler/src/ReactFiberBeginWork.new.js | 4 +++- packages/react-reconciler/src/ReactFiberBeginWork.old.js | 4 +++- packages/react-reconciler/src/__tests__/ReactMemo-test.js | 6 ++++++ 3 files changed, 12 insertions(+), 2 deletions(-) diff --git a/packages/react-reconciler/src/ReactFiberBeginWork.new.js b/packages/react-reconciler/src/ReactFiberBeginWork.new.js index ace4f1b4c708f..13f0d6b6f5145 100644 --- a/packages/react-reconciler/src/ReactFiberBeginWork.new.js +++ b/packages/react-reconciler/src/ReactFiberBeginWork.new.js @@ -592,7 +592,9 @@ function updateSimpleMemoComponent( } if (current !== null) { const prevProps = current.memoizedProps; - nextProps = shallowEqual(prevProps, nextProps) ? prevProps : nextProps; + workInProgress.pendingProps = nextProps = shallowEqual(prevProps, nextProps) + ? prevProps + : nextProps; if ( prevProps === nextProps && current.ref === workInProgress.ref && diff --git a/packages/react-reconciler/src/ReactFiberBeginWork.old.js b/packages/react-reconciler/src/ReactFiberBeginWork.old.js index a22e3b377ced6..dba5339412abb 100644 --- a/packages/react-reconciler/src/ReactFiberBeginWork.old.js +++ b/packages/react-reconciler/src/ReactFiberBeginWork.old.js @@ -592,7 +592,9 @@ function updateSimpleMemoComponent( } if (current !== null) { const prevProps = current.memoizedProps; - nextProps = shallowEqual(prevProps, nextProps) ? prevProps : nextProps; + workInProgress.pendingProps = nextProps = shallowEqual(prevProps, nextProps) + ? prevProps + : nextProps; if ( prevProps === nextProps && current.ref === workInProgress.ref && diff --git a/packages/react-reconciler/src/__tests__/ReactMemo-test.js b/packages/react-reconciler/src/__tests__/ReactMemo-test.js index 7dd0b84609d97..5169767f8227f 100644 --- a/packages/react-reconciler/src/__tests__/ReactMemo-test.js +++ b/packages/react-reconciler/src/__tests__/ReactMemo-test.js @@ -222,6 +222,12 @@ describe('memo', () => { expect(ReactNoop.getChildren()).toEqual([ span('Inner render count: 1'), ]); + + ReactNoop.render(); + expect(Scheduler).toFlushAndYield([]); + expect(ReactNoop.getChildren()).toEqual([ + span('Inner render count: 1'), + ]); }); it('accepts custom comparison function', async () => {