Sobes.tech
Назад к вопросам
Middle+
4

// Нужно сделать новый компонент RandOnce на основе компонента Rand, // который при использовании в App // не будет обновлять случайное число каждые 3 секунды, а выведет случайно число только 1 раз. // const Rand = () => <span>{Math.random()}</span>

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

Ответ от нейросети

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 просто не устанавливает такой таймер и сохраняет число постоянным.