Назад к задачам
Junior — Senior
12

Повышение производительности React‑компонентов

Компании, где спрашивали:

Т-БанкТ-Банк
Получайте помощь с лайвкодингом в реальном времени с Sobes Copilot
Условие задачи

Требуется улучшить представленный React‑пример так, чтобы компонент Child не перерисовывался при вводе текста в поле ввода.

import React from 'react';

export default function App() {
  const triggerRender = useForceUpdate();
  return (
    <div style={{ margin: '20px', padding: '20px', border: '2px solid green' }}>
      <button onClick={triggerRender}>Render</button>
      <RenderCount />
      <Parent />
    </div>
  );
}

const Parent = () => {
  const [text, setText] = React.useState('');
  const onInputChange = (e) => {
    setText(e.target.value);
  };
  return (
    <form style={{ margin: '20px', padding: '20px', border: '2px solid blue' }}>
      Input value is: {text}
      <RenderCount />
      <Child onChange={onInputChange} />
    </form>
  );
};

const Child = ({ onChange }) => {
  return (
    <div style={{ padding: '20px', margin: '20px', border: '2px solid red' }}>
      <input type="text" name="value" onChange={onChange} />
      <RenderCount />
    </div>
  );
};

function RenderCount() {
  const renderCount = React.useRef(1);
  React.useEffect(() => {
    renderCount.current += 1;
  });
  return (
    <div style={{ marginTop: '10px' }}>
      Render count: {renderCount.current}
    </div>
  );
}

Задача — применить подходящие техники (например, React.memo, useCallback и т.п.), чтобы дочерний компонент оставался неизменным при каждом изменении состояния ввода в родителе.