diff --git a/packages/react-dom/src/__tests__/ReactDOMFiber-test.js b/packages/react-dom/src/__tests__/ReactDOMFiber-test.js index 864caa0f3358f..c19777e7e56a3 100644 --- a/packages/react-dom/src/__tests__/ReactDOMFiber-test.js +++ b/packages/react-dom/src/__tests__/ReactDOMFiber-test.js @@ -461,6 +461,40 @@ describe('ReactDOMFiber', () => { expect(container.innerHTML).toBe('
'); }); + it('should unmount empty portal component wherever it appears', () => { + const portalContainer = document.createElement('div'); + + class Wrapper extends React.Component { + constructor(props) { + super(props); + this.state = { + show: true, + }; + } + render() { + return ( +
+ {this.state.show && ( + + {ReactDOM.createPortal(null, portalContainer)} +
child
+
+ )} +
parent
+
+ ); + } + } + + const instance = ReactDOM.render(, container); + expect(container.innerHTML).toBe( + '
child
parent
', + ); + instance.setState({show: false}); + expect(instance.state.show).toBe(false); + expect(container.innerHTML).toBe('
parent
'); + }); + it('should keep track of namespace across portals (simple)', () => { assertNamespacesMatch( diff --git a/packages/react-reconciler/src/ReactFiberCommitWork.js b/packages/react-reconciler/src/ReactFiberCommitWork.js index 85231dd068bf8..06ad89eaf1310 100644 --- a/packages/react-reconciler/src/ReactFiberCommitWork.js +++ b/packages/react-reconciler/src/ReactFiberCommitWork.js @@ -1038,12 +1038,12 @@ function unmountHostComponents(current): void { } // Don't visit children because we already visited them. } else if (node.tag === HostPortal) { - // When we go into a portal, it becomes the parent to remove from. - // We will reassign it back when we pop the portal on the way up. - currentParent = node.stateNode.containerInfo; - currentParentIsContainer = true; - // Visit children because portals might contain host components. if (node.child !== null) { + // When we go into a portal, it becomes the parent to remove from. + // We will reassign it back when we pop the portal on the way up. + currentParent = node.stateNode.containerInfo; + currentParentIsContainer = true; + // Visit children because portals might contain host components. node.child.return = node; node = node.child; continue;