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

// Необходимо вынести логику перерендерa в отдельный внешний хук, // который дает возможность из вне работать с таймером (например остановить через 10 секунд). // Нужно сделать новый компонент RandOnce на основе компонента Rand, // который при использовании в App // не будет обновлять случайное число каждые 3 секунды, а выведет случайно число только 1 раз.

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

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

sobes.tech AI

Для решения задачи нужно вынести логику перерендеринга с таймером в отдельный кастомный хук, который будет возвращать текущее случайное число и методы управления таймером (например, остановку). Затем на его основе сделать компонент RandOnce, который вызовет хук, но не будет запускать обновление по таймеру, а выведет число один раз.

Пример реализации:

import React, { useState, useEffect, useRef } from 'react';

// Хук с таймером для обновления случайного числа
function useRandomTimer(interval = 3000) {
  const [random, setRandom] = useState(Math.random());
  const timerId = useRef(null);

  useEffect(() => {
    timerId.current = setInterval(() => {
      setRandom(Math.random());
    }, interval);

    return () => clearInterval(timerId.current);
  }, [interval]);

  const stop = () => {
    if (timerId.current) {
      clearInterval(timerId.current);
      timerId.current = null;
    }
  };

  return { random, stop };
}

// Компонент Rand — обновляет число каждые 3 секунды
export function Rand() {
  const { random } = useRandomTimer(3000);
  return <div>{random}</div>;
}

// Компонент RandOnce — выводит число один раз, без обновлений
export function RandOnce() {
  const [random] = useState(Math.random());
  // Можно использовать хук без запуска таймера или просто не использовать хук
  return <div>{random}</div>;
}

// Если нужно, можно сделать useRandomTimer с опцией, чтобы не запускать таймер
function useRandomTimerControlled(interval = 3000, start = true) {
  const [random, setRandom] = useState(Math.random());
  const timerId = useRef(null);

  useEffect(() => {
    if (!start) return;
    timerId.current = setInterval(() => {
      setRandom(Math.random());
    }, interval);

    return () => clearInterval(timerId.current);
  }, [interval, start]);

  const stop = () => {
    if (timerId.current) {
      clearInterval(timerId.current);
      timerId.current = null;
    }
  };

  return { random, stop };
}

// Тогда RandOnce можно сделать так:
export function RandOnceControlled() {
  const { random } = useRandomTimerControlled(3000, false); // таймер не запускается
  return <div>{random}</div>;
}

Таким образом, логика обновления вынесена в хук, который можно контролировать извне, а компонент RandOnce выводит число один раз без обновлений.