设计高性能react组件的思路

本文探讨如何提升React组件的性能,主要关注shouldComponentUpdate生命周期方法的使用,以及PureComponent的原理。通过避免不必要的渲染,减少重绘和重排,提升应用的运行效率。文中通过实例展示了如何利用shouldComponentUpdate避免组件B的冗余渲染,并介绍了PureComponent通过浅比较优化组件更新的过程。
摘要由CSDN通过智能技术生成

对于一个高性能的react组件来说,减少重绘和重排、减少服务器渲染等很重要。

在一个react应用中,是通过react组件的形式来组织逻辑,把UI拆分为多个独立的、可复用的组件,那就恶意从组件的渲染角度来考虑组件性能优化:

  1. 使用shouldComponentUpdate来避免重复的更新逻辑
  2. 通过PureComponent + Immutable.js
  3. React.memo和useMemo

shouldComponentUpdate

shouldComponentUpdate是react类组件的一个生命周期,react组件是根据shouldComponentUpdate的返回值来判断是否对组件进行重新渲染的。

shouldComponentUpdate的默认值是true,现在有这么一个组件组合:
App组件包含组件A和组件B:

组件A:

import React from "react";
export default class ChilA extends React.Component {
    render() {
        console.log("ChildA的render执行了");
        return (
            <div>
                A组件的内容
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

读心悦

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值