React组件状态下移和内容提升怎么实现
导读:本文共1934.5字符,通常情况下阅读需要6分钟。同时您也可以点击右侧朗读,来听本文内容。按键盘←(左) →(右) 方向键可以翻页。
摘要:希望大家仔细阅读,能够学有所成!前言两个简单实用的优化组件渲染性能的方法:状态下移内容提升在讲解这两种方法之前,我们需要先手动创建一个有严重渲染性能的组件,如下所示:import{useState}from'react';exportdefaultfunctionApp(){let[color,setColor]=useState('red');return(... ...
目录
(为您整理了一些要点),点击可以直达。希望大家仔细阅读,能够学有所成!
两个简单实用的优化组件渲染性能的方法:
状态下移
内容提升
在讲解这两种方法之前,我们需要先手动创建一个有严重渲染性能的组件,如下所示:
很显然,当 App 组件内的状态发生了改变,ExpensiveTree 组件会 re-render, 事实上 ExpensiveTree 组件的 props、state 并未发生改变,这并不是我们期望的结果,下面将提供两种简单的方法,提升组件渲染的性能;
我们可以看到以上 ExpensiveTree 组件并不依赖 App 组件内部的状态,因此我们是否可以考虑,将依赖 color 的元素抽离到一个依赖 color 的组件中呢?
下面是实践后的代码:
此时,将依赖 color 的元素提取到了 Form 组件中,Form 组件内部的状态不再影响 ExpensiveTree 组件的渲染,问题便得到了解决
以上情况是高开销组件 ExpensiveTree 的父节点依赖 color,此时显然状态下移是行不通的,但是还有另外一种办法:
此时和状态提升是完全相反的,将依赖 color 的元素提升到了 ColorPicker 组件中,而不依赖 color 的元素以 children prop 的形式传入了 ColorPicker ,当组件内部的状态改变时:
ColorPicker 会重新渲染但是它仍然保存着
ColorPicker 的 children 属性未变化 React 并不会访问那棵子树。 因此,ExpensiveTree不会重新渲染。
React组件状态下移和内容提升怎么实现的详细内容,希望对您有所帮助,信息来源于网络。