Назад к задачам
Т-БанкПолучайте помощь с лайвкодингом в реальном времени с Sobes Copilot
Junior — Senior
12
Повышение производительности React‑компонентов
Компании, где спрашивали:
Условие задачи
Требуется улучшить представленный 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 и т.п.), чтобы дочерний компонент оставался неизменным при каждом изменении состояния ввода в родителе.