Reagovat Memo


Použití memozpůsobí, že React přeskočí vykreslování komponenty, pokud se její vlastnosti nezměnily.

To může zlepšit výkon.

Tato sekce používá React Hooks. Další informace o hácích najdete v sekci React Hooks.


Problém

V tomto příkladu se Todoskomponenta znovu vykreslí, i když se úkoly nezměnily.

Příklad:

index.js:

import { useState } from "react";
import ReactDOM from "react-dom";
import Todos from "./Todos";

const App = () => {
  const [count, setCount] = useState(0);
  const [todos, setTodos] = useState(["todo 1", "todo 2"]);

  const increment = () => {
    setCount((c) => c + 1);
  };

  return (
    <>
      <Todos todos={todos} />
      <hr />
      <div>
        Count: {count}
        <button onClick={increment}>+</button>
      </div>
    </>
  );
};

ReactDOM.render(<App />, document.getElementById('root'));

Todos.js:

const Todos = ({ todos }) => {
  console.log("child render");
  return (
    <>
      <h2>My Todos</h2>
      {todos.map((todo, index) => {
        return <p key={index}>{todo}</p>;
      })}
    </>
  );
};

export default Todos;

Když kliknete na tlačítko zvýšení, Todoskomponenta se znovu vykreslí.

Pokud by tato součást byla složitá, mohlo by to způsobit problémy s výkonem.


w3schools CERTIFIED . 2022

Získejte certifikaci!

Dokončete moduly React, proveďte cvičení, udělejte zkoušku a získejte certifikaci w3schools!!

95 $ PŘIHLÁSIT SE

Řešení

Abychom to napravili, můžeme použít memo.

Použijte memo, aby se Todoskomponenta zbytečně znovu nevykreslovala.

Zabalte Todosexport komponenty do memo:

Příklad:

index.js:

import { useState } from "react";
import ReactDOM from "react-dom";
import Todos from "./Todos";

const App = () => {
  const [count, setCount] = useState(0);
  const [todos, setTodos] = useState(["todo 1", "todo 2"]);

  const increment = () => {
    setCount((c) => c + 1);
  };

  return (
    <>
      <Todos todos={todos} />
      <hr />
      <div>
        Count: {count}
        <button onClick={increment}>+</button>
      </div>
    </>
  );
};

ReactDOM.render(<App />, document.getElementById('root'));

Todos.js:

import { memo } from "react";

const Todos = ({ todos }) => {
  console.log("child render");
  return (
    <>
      <h2>My Todos</h2>
      {todos.map((todo, index) => {
        return <p key={index}>{todo}</p>;
      })}
    </>
  );
};

export default memo(Todos);

Nyní se Todoskomponenta znovu vykreslí pouze tehdy, když todosjsou aktualizovány prvky, které jsou jí předány prostřednictvím rekvizit.