From 99158915c527f0ef9e9ca7d70aceea4e99f9a29b Mon Sep 17 00:00:00 2001 From: CJY Date: Tue, 16 Nov 2021 12:16:48 +0800 Subject: [PATCH] =?UTF-8?q?feat:=20=E5=A2=9E=E5=8A=A0=20react-freeze=20?= =?UTF-8?q?=E8=BF=9B=E8=A1=8C=E7=BC=93=E5=AD=98=E7=8A=B6=E6=80=81=E4=B8=8B?= =?UTF-8?q?=E7=9A=84=E6=80=A7=E8=83=BD=E4=BC=98=E5=8C=96?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- package.json | 1 + src/core/Keeper.js | 51 +++++++++++++++++++++++++++++----------------- 2 files changed, 33 insertions(+), 19 deletions(-) diff --git a/package.json b/package.json index 6979e2f..12f8cba 100644 --- a/package.json +++ b/package.json @@ -43,6 +43,7 @@ "create-react-context": "^0.3.0", "hoist-non-react-statics": "^3.3.0", "jsx-ast-utils": "^2.2.1", + "react-freeze": "1.0.0", "react-node-key": "^0.3.0", "szfe-tools": "^0.0.0-beta.7" }, diff --git a/src/core/Keeper.js b/src/core/Keeper.js index c41713a..15a7210 100644 --- a/src/core/Keeper.js +++ b/src/core/Keeper.js @@ -1,10 +1,13 @@ -import React, { PureComponent } from 'react' -import { get, run, isArray, nextTick, EventBus } from 'szfe-tools' +import React, { PureComponent, Suspense } from 'react' +import { get, run, nextTick, EventBus } from 'szfe-tools' +import { Freeze as ReactFreeze } from 'react-freeze' import Bridge from './Bridge' import { AliveNodeProvider } from './context' import { LIFECYCLE_ACTIVATE, LIFECYCLE_UNACTIVATE } from './lifecycles' +const Freeze = !!Suspense ? ReactFreeze : ({ children }) => children + export default class Keeper extends PureComponent { eventBus = new EventBus() listeners = new Map() @@ -17,6 +20,7 @@ export default class Keeper extends PureComponent { children: props.children, bridgeProps: props.bridgeProps, key: Math.random(), + freeze: false, } } @@ -68,6 +72,9 @@ export default class Keeper extends PureComponent { } [LIFECYCLE_ACTIVATE]() { + this.setState({ + freeze: false, + }) this.eventBus.emit(LIFECYCLE_ACTIVATE) this.listeners.forEach((listener) => run(listener, [LIFECYCLE_ACTIVATE])) } @@ -79,6 +86,10 @@ export default class Keeper extends PureComponent { listeners .reverse() .forEach(([, listener]) => run(listener, [LIFECYCLE_UNACTIVATE])) + + this.setState({ + freeze: true, + }) } // // 原先打算更新过程中先重置 dom 节点状态,更新后恢复 dom 节点 @@ -171,26 +182,28 @@ export default class Keeper extends PureComponent { render() { const { id, ...props } = this.props - const { children, bridgeProps, key } = this.state + const { children, bridgeProps, key, freeze } = this.state return ( -
{ - this.wrapper = node - }} - > -
- - - {React.Children.map(children, (child, idx) => - React.cloneElement(child, { - key: `${child.key || ''}:${key}:${idx}`, - }) - )} - - + +
{ + this.wrapper = node + }} + > +
+ + + {React.Children.map(children, (child, idx) => + React.cloneElement(child, { + key: `${child.key || ''}:${key}:${idx}`, + }) + )} + + +
-
+ ) } }