如果我有一个包含多个子组件的父组件,并且如果我更新父组件将反应重新渲染整个父组件包括子组件?
是的,它将默认重新渲染所有嵌套的子组件 . 然而,在引擎盖下反应应用diffing算法来确定最终需要最终更新的dom节点 . 在大多数情况下,这种差异足够快且足够快 . 如果遇到性能问题,请查看生命周期方法shouldComponentUpdate(),您可以在其中定义是否将重新呈现组件(及其子项) .
例如,如果您只想在 myProp 更改时重新渲染组件:
myProp
shouldComponentUpdate(nextProps, nextState) { if (this.props.myProp !== nextProps.myProp) { return true } return false }
1 回答
是的,它将默认重新渲染所有嵌套的子组件 . 然而,在引擎盖下反应应用diffing算法来确定最终需要最终更新的dom节点 . 在大多数情况下,这种差异足够快且足够快 . 如果遇到性能问题,请查看生命周期方法shouldComponentUpdate(),您可以在其中定义是否将重新呈现组件(及其子项) .
例如,如果您只想在
myProp
更改时重新渲染组件: