Форум программистов, компьютерный форум, киберфорум
React/ReactJS
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 5.00/3: Рейтинг темы: голосов - 3, средняя оценка - 5.00
123 / 98 / 15
Регистрация: 02.02.2014
Сообщений: 346

getDerivedStateFromProps и setTimeOut

14.07.2021, 19:21. Показов 744. Ответов 2
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Подскажите такую вещь, я не до конца догоняю логики реакта, времени не особо много на доки.


App

JavaScript
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
export default class App extends React.Component{
    constructor(props){
        super(props)
         ...
          
        this.state={
             ... 
            topActionPreloader: false,
     
        }
 
        ...
        render(){
         
            return (
            <div className="App">
                 <TopActionPreloader status={this.state.topActionPreloader} />
               ...
             </div>
            ) 
    }
    }
тут сам прелоадер

JavaScript
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
export default class TopActionPreloader  extends React.Component{
    
    constructor(props){
            super(props) 
            this.state =  {
                status: props.status, 
            };  
    }
    
   
    
    static getDerivedStateFromProps(props, state) { 
        return {
            status: props.status,  
          };
      }
     ...
 
}
Хочу чтобы у прелоадера было три состояния.
Но, когда состояние complete, через секунду оно должно стать false
куда нужно поставить setTimeOut в компоненте прелоадера ?
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
14.07.2021, 19:21
Ответы с готовыми решениями:

getDerivedStateFromProps
Может кто нибудь привести пример кода с целесообразным примером использование метода компонента getDerivedStateFromProps Пока что вообще не...

setTimeout
вот ф-ция setTimeout (function(){ jQuery(document).ready(function(){ // Instantiate jTicker jQuery(&quot;#ticker&quot;).ticker({ ...

setTimeout
Добрый день! Подскажите, почему не работает setTimeout? const list = document.querySelector(&quot;.list&quot;); const home =...

2
 Аватар для Ovederax
604 / 404 / 212
Регистрация: 30.04.2017
Сообщений: 744
Записей в блоге: 1
14.07.2021, 19:44
я бы переписал на функциональный компонент и засунул в useEffect

насчет класового, не знаю,
по жизненому циклу подходит constructor и shouldComponentUpdate либо componentDidMount + componentDidUpdate,
по идее только туда и можно такую логику закинуть
https://ru.reactjs.org/docs/react-component.html

JavaScript
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
const TopActionPreloader = props => {
  const [status, setStatus] = useState(props.status || 'initial');
  useEffect(() => {
    setStatus(props.status);
    if (props.status === 'complete') setTimeout(() => setStatus('false'), 1000);
  }, [props.status]);
  return status;
};
 
const App = () => {
  const [status, setStatus] = useState('initial');
  return (
    <div>
      <button
        onClick={() => {
          if (status === 'initial') setStatus('complete');
          else setStatus('initial');
        }}
      >
        Click me
      </button>
      <TopActionPreloader status={status} />
    </div>
  );
};
0
123 / 98 / 15
Регистрация: 02.02.2014
Сообщений: 346
25.07.2021, 14:37  [ТС]
не . это не то. сделал через рефы.
а в реакте можно как то шину сделать между компонентами?
например в Vue есть bus

Добавлено через 1 минуту
всё. нашел
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
25.07.2021, 14:37
Помогаю со студенческими работами здесь

SetTimeout
... хотя может быть проблема в чём-то другом (руки неоттуда растут?), но я всёже грешу на этот гадский таймер. Короче, я пытаюсь сделать,...

SetTimeout
Привет знатокам. У меня не большая проблема с таймером. Хочу что бы сообщение выбилось через 1 секунду. ...

SetTimeout
Надо чтобы квадраты меняли цвет на зеленый, сначала один, потом другой и снова. Что тут может быть не так? &lt;!DOCTYPE html&gt; ...

Зациклить setTimeout
Добрый день! Как зациклить анимацию клика? Использую for, но не помогает. Всё равно останавливается. $(document).ready(function()...

Рекурсивный setTimeout
А можно ли сделать несколько последовательных рекурсивных setTimeout, чтобы между ними очищался стэк? То есть, один рекурсивный блок...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Обработчик клика мыши в браузере ПК и касания экрана в браузере на мобильном устройстве
8Observer8 02.02.2026
Содержание блога Для начала пошагово создадим рабочий пример для подготовки к экспериментам в браузере ПК и в браузере мобильного устройства. Потом напишем обработчик клика мыши и обработчик. . .
Философия технологии
iceja 01.02.2026
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
SDL3 для Web (WebAssembly): Вывод текста со шрифтом TTF с помощью SDL3_ttf
8Observer8 01.02.2026
Содержание блога В этой пошаговой инструкции создадим с нуля веб-приложение, которое выводит текст в окне браузера. Запустим на Android на локальном сервере. Загрузим Release на бесплатный. . .
SDL3 для Web (WebAssembly): Сборка C/C++ проекта из консоли
8Observer8 30.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
SDL3 для Web (WebAssembly): Установка Emscripten SDK (emsdk) и CMake для сборки C и C++ приложений в Wasm
8Observer8 30.01.2026
Содержание блога Для того чтобы скачать Emscripten SDK (emsdk) необходимо сначало скачать и уставить Git: Install for Windows. Следуйте стандартной процедуре установки Git через установщик. . . .
SDL3 для Android: Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 29.01.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами. Версия v3 была полностью переписана на Си, в. . .
Инструменты COM: Сохранение данный из VARIANT в файл и загрузка из файла в VARIANT
bedvit 28.01.2026
Сохранение базовых типов COM и массивов (одномерных или двухмерных) любой вложенности (деревья) в файл, с возможностью выбора алгоритмов сжатия и шифрования. Часть библиотеки BedvitCOM Использованы. . .
SDL3 для Android: Загрузка PNG с альфа-каналом с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 28.01.2026
Содержание блога SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru