Форум программистов, компьютерный форум, киберфорум
React/ReactJS
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.88/8: Рейтинг темы: голосов - 8, средняя оценка - 4.88
3 / 3 / 1
Регистрация: 20.02.2018
Сообщений: 126

useState initial state или useEffect

08.01.2021, 11:54. Показов 1691. Ответов 1
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте!!!
Я так понял что можно в useState передать функцию и стелать както так:
JavaScript
1
2
3
4
    const [articles, setArticles] = useState<IInitialValues[]>(() => {
        const saved = localStorage.getItem('articles') || '[]';
        return JSON.parse(saved);
    });
а можно articles установить через useEffect при первом рендере. Так вот я никак не пойму тут есть какойто подвох? или делай как хочешь?
0
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
08.01.2021, 11:54
Ответы с готовыми решениями:

Почему при попытке обновить state из useEffect он не обновляется?
Почему при попытке обновить tabsFields из useEffect он не обновляется? // Apollo Client запрос к GraphQL серверу const {...

Изменение состояния useState
Есть такой код: import React, { useState } from 'react' const Task = () =&gt; { const = useState( {name: 'Иван', age: 25,...

Route и UseEffect
Всем привет ! Вот код. //----TASKS------------------------- export const Tasks =() =&gt; {return...

1
Эксперт JS
 Аватар для Iverycool
1586 / 796 / 362
Регистрация: 01.02.2019
Сообщений: 1,047
10.01.2021, 13:28
Лучший ответ Сообщение было отмечено riddlejs как решение

Решение

riddlejs, это весьма интересный вопрос, ведь в официальной документации этот момент не освещается
В принципе, получение данных из сторонних источников(к которым относится и localStorage) должно производиться через useEffect, но localStorage при этом работает синхронно, следовательно и серьёзной разницы, где вы запросите у него данные(в useEffect или useState), казалось бы нет. НО. Более верным будет использование useState, так как если мы вначале зададим state как null, а затем уже эффектом обновим его, то это, возможно, и не будет лишней перерисовкой, но React совершит лишние перерасчёты.
Также я нашёл в интернете два примера с useState: https://habr.com/ru/post/520370/, https://codesandbox.io/s/wymmko1w28 и пользовательский хук useLocalStorage, основанный на этом же подходе.
2
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
10.01.2021, 13:28
Помогаю со студенческими работами здесь

Adodb Connection state 1, ADODB Recordset state 0
добрый день. подскажите, пожалуйста, в чем может быть проблема? ошибку выдает &quot;вызванный объект был отключен от клиентов&quot; или...

Too many initial conditions
Собственно вот что выдает, уже все перепробовал, может кто подскажет в чем ошибка?

Too many initial conditions
Ночи доброй. Подскажите что нужно поправить что бы все получилось и построился график.

Initial css
Доброй ночи. Спасайте initial во всех браузерах работает кроме IE, а без initial не как. Можно как то для IE прописать его ? Или есть...

Simulink. Initial value for Gain block
Здравствуйте! Как задать значение переменной(например, К6), которая используется в блоке Gain : Заранее спс!


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
Как дизайн сайта влияет на конверсию: 7 решений, которые реально повышают заявки
Neotwalker 08.03.2026
Многие до сих пор воспринимают дизайн сайта как “красивую оболочку”. На практике всё иначе: дизайн напрямую влияет на то, оставит человек заявку или уйдёт через несколько секунд. Даже если у вас. . .
Модульная разработка через nuget packages
DevAlt 07.03.2026
Сложившийся в . Net-среде способ разработки чаще всего предполагает монорепозиторий в котором находятся все исходники. При создании нового решения, мы просто добавляем нужные проекты и имеем. . .
Модульный подход на примере F#
DevAlt 06.03.2026
В блоге дяди Боба наткнулся на такое определение: В этой книге («Подход, основанный на вариантах использования») Ивар утверждает, что архитектура программного обеспечения — это структуры,. . .
Управление камерой с помощью скрипта OrbitControls.js на Three.js: Вращение, зум и панорамирование
8Observer8 05.03.2026
Содержание блога Финальная демка в браузере работает на Desktop и мобильных браузерах. Итоговый код: orbit-controls-threejs-js. zip. Сканируйте QR-код на мобильном. Вращайте камеру одним пальцем,. . .
SDL3 для Web (WebAssembly): Синхронизация спрайтов SDL3 и тел Box2D
8Observer8 04.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-sync-physics-sprites-sdl3-c. zip На первой гифке отладочные линии отключены, а на второй включены:. . .
SDL3 для Web (WebAssembly): Идентификация объектов на Box2D v3 - использование userData и событий коллизий
8Observer8 02.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-collision-events-sdl3-c. zip Сканируйте QR-код на мобильном и вы увидите, что появится джойстик для управления главным героем. . . .
Реалии
Hrethgir 01.03.2026
Нет, я не закончил до сих пор симулятор. Эта задача сложнее. Не получилось уйти в плавсостав, но оно и к лучшему, возможно. Точнее получалось - но сварщиком в палубную команду, а это значит, в моём. . .
Ритм жизни
kumehtar 27.02.2026
Иногда приходится жить в ритме, где дел становится всё больше, а вовлечения в происходящее — всё меньше. Плотный график не даёт вниманию закрепиться ни на одном событии. Утро начинается с быстрых,. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru