React.memo基础使用

说明

React组件默认的渲染机制:只要父组件重新渲染,子组件就会重新渲染。

而React.memo允许组件在Props没有改变的情况下跳过渲染。

https://zh-hans.react.dev/reference/react/memo

import { memo } from 'react';

const SomeComponent = memo(function SomeComponent(props) {
  // ...
});

返回值:memo 返回一个新的 React 组件。它的行为与提供给 memo 的组件相同,只是当它的父组件重新渲染时 React 不会总是重新渲染它,除非它的 props 发生了变化。

使用 memo 将组件包装起来,以获得该组件的一个 记忆化 版本。通常情况下,只要该组件的 props 没有改变,这个记忆化版本就不会在其父组件重新渲染时重新渲染。但 React 仍可能会重新渲染它:记忆化是一种性能优化,而非保证。

示例

演示不使用React.memo,默认渲染机制:父组件重新渲染,子组件也会被重新渲染

import { useState } from "react"

function Son() {
  console.log('子组件重新渲染了')
  return <div>this is son</div>
}

function App() {
  const [count, setCount] = useState(0)
  console.log('父组件重新渲染了')

  return (
    <div>
      <button onClick={() => setCount(count + 1)}>点击自增count</button>
      <Son />
    </div >
  )
}

export default App

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

使用memo函数进行缓存

import { memo, useState } from "react"

// 使用memo函数进行缓存,只有props发生变化的时候,才会重新渲染
const MemoSon = memo(function Son() {
  console.log('子组件重新渲染了')
  return <div>this is son</div>
})


// function Son() {
//   console.log('子组件重新渲染了')
//   return <div>this is son</div>
// }

function App() {
  const [count, setCount] = useState(0)
  console.log('父组件重新渲染了')

  return (
    <div>
      <button onClick={() => setCount(count + 1)}>点击自增count</button>
      <MemoSon />
    </div >
  )
}

export default App

初始渲染:
在这里插入图片描述

点击按钮,改变值,引起父组件的重新渲染,但此时子组件没有重新渲染:
在这里插入图片描述

  • 3
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
React是最常用的JavaScript库之一,用于构建用户界面。React提供了一组用于构建不同类型应用的方法。其中之一就是React.memo()方法。React.memo()方法用于优化React应用。它会缓存组件的渲染结果,并在组件的props没有变化时,直接使用缓存的结果。这样可以避免无用的渲染操作并提高应用的性能。 使用React.memo()方法很简单。只需要在定义组件时使用它即可: ``` import React from 'react'; const MyComponent = React.memo((props) => { /* 组件的代码 */ }); ``` React.memo()方法返回一个高阶组件,它会将组件进行包装并缓存结果。当组件的props没有发生改变时,它会直接使用缓存的结果。如果props发生了改变,React.memo()方法会重新渲染组件并缓存新的结果。 React.memo()方法还有一个可选的第二个参数,它是一个比较函数。比较函数用于检查组件的props是否已更改。如果props相同,则使用缓存的渲染结果。如果props不同,则重新渲染组件并缓存新的结果。 ``` import React from 'react'; const MyComponent = React.memo((props) => { /* 组件的代码 */ }, (prevProps, nextProps) => { if (prevProps.data == nextProps.data) { return true; } else { return false; } }); ``` 在这个例子中,我们定义了一个比较函数,它检查props中的data是否相等。如果相等,则使用缓存的结果。如果不相等,则重新渲染组件。 在实际开发中,我们可以使用React.memo()方法对那些不经常改变的组件进行优化,以提高应用的性能。但要注意,React.memo()方法并不是对所有组件都适用的。例如,如果组件非常简单,或者其props经常改变,则使用React.memo()方法可能会降低性能。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值