Back to questions
Middle+
3
// Нужно сделать новый компонент RandOnce на основе компонента Rand, // который при использовании в App // не будет обновлять случайное число каждые 3 секунды, а выведет случайно число только 1 раз. // const Rand = () => <span>{Math.random()}</span>
Companies where asked
VK Tech
Answer from AI
sobes.tech AI
Чтобы компонент RandOnce выводил случайное число только один раз при первом рендере и не обновлялся каждые 3 секунды, можно использовать хук useState или useMemo для генерации числа один раз.
Пример реализации:
import React, { useState } from 'react';
const RandOnce = () => {
const [random] = useState(() => Math.random());
return <span>{random}</span>;
};
// Использование в App
const App = () => {
return <RandOnce />;
};
Здесь useState с функцией инициализации гарантирует, что Math.random() вызовется только один раз при монтировании компонента, и значение сохранится при последующих рендерах.
Если исходный компонент Rand обновляет число каждые 3 секунды через таймер, то RandOnce просто не устанавливает такой таймер и сохраняет число постоянным.