Форум программистов, компьютерный форум, киберфорум
React/ReactJS
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
0 / 0 / 0
Регистрация: 30.12.2020
Сообщений: 109

LocalStorage очищается после обновления страницы

12.08.2022, 17:23. Показов 2133. Ответов 0

Студворк — интернет-сервис помощи студентам
Работаю с LocalStorage впервые и если использовать обычный метод localStorage.setItem, то все работает. Однако нужно подключить функию с другого файла. И вроде оно создается, однако после обновления страницы стирается. Подскажите, как это исправить?

Мой файл, где используется функция
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
26
27
28
29
30
31
32
33
34
35
import { useState, useCallback, useEffect } from "react"
import LocalStorage from "./localStorage"
 
export const useAuth = () => {
    const [token, setToken] = useState(null)
    const [userId, setUserId] = useState(null)
    const [ready, setReady] = useState(false)
 
    const login = useCallback( (jwtToken, id)=>{
        setToken(jwtToken)
        setUserId(id) 
 
        LocalStorage.setItem('Person', {token: jwtToken, userId: id})
    }, [])
 
    const logout = useCallback( ()=>{
        setToken(null)
        setUserId(null) 
 
        LocalStorage.removeItem('Person')
    }, [])
 
    useEffect( () =>{
        try {
            const data = JSON.parse(LocalStorage.getItem('Person'))
            if (data && data.token) {
                login(data.token, data.userId)
            }
            setReady(true)
        } catch (error) {}
        
    }, [login])
 
    return {login, logout, token, userId, ready}
}
Файл с функцией
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
26
27
28
29
30
31
32
33
34
35
let isLocalStorageSupported = typeof localStorage === 'object';
 
try {
  localStorage.setItem("Person", 'test');
  localStorage.removeItem("Person");
} catch (e) {
  isLocalStorageSupported = false;
  
  if (e.code === DOMException.QUOTA_EXCEEDED_ERR && localStorage.length === 0) {} 
  else {throw e;}
}
 
const LocalStorage = {
  getItem: (key) => {
    if (isLocalStorageSupported) {
      return JSON.parse(localStorage.getItem(key));
    }
    return null;
  },
 
  setItem: (key, value) => {
    if (isLocalStorageSupported) {
      localStorage.setItem(key, value);
    }
  },
 
  removeItem: (key) => {
    if (isLocalStorageSupported) {
      localStorage.removeItem(key);
    }
  },
};
 
 
export default LocalStorage;
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
12.08.2022, 17:23
Ответы с готовыми решениями:

Как запустить контент скрипт после ajax обновления страницы
У меня есть расширение, нажимающее на кнопки, и есть сайт, в котором страницы обновляются, как я понял, через ajax (url меняется, меняется...

SetInterval() после обновления страницы
Здравствуйте! setInterval() после обновления страницы останавливается и запускается заново или запускает дубли? Нужно ли после...

Not Found после обновления страницы
Всем привет! Прошу помочь, Гугл, что то не справился. Какие то советы есть, но они мне не помогли. Создал приложение на React Js , на...

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

Таймер сбрасывается после обновления страницы
Необходимо, чтобы при перезагрузке страницы таймер нахождения на странице продолжал отсчет. Знаю, что можно как-то сделать это с помощью...

Переход в начало страницы после её обновления
Дело вот в чем, я захожу на сайт , пролистываю вниз , обновляю страницу и остаюсь на том же месте, при этом скрипты выше отрабатывают и...

Обновление страницы после обновления базы
Есть textarea для редактирования модели item и метод updateAfterEdit который находится в фабрике User и обновляющий базу по таймауту. ...

Скрипт срабатывает только после обновления страницы
Здравствуйте, у меня появилась проблема и хотелось бы посоветоваться с знающими людьми. Суть такова, мой скрипт срабатывает только после...

Запомнить горизонтальный скролл после обновления страницы
Доброго времени суток! Подскажите как можно запомнить горизонтальный скролл после обновления страницы, есть див <div...


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

Или воспользуйтесь поиском по форуму:
1
Ответ Создать тему
Новые блоги и статьи
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
Фото: Daniel Greenwood
kumehtar 13.11.2025
Расскажи мне о Мире, бродяга
kumehtar 12.11.2025
— Расскажи мне о Мире, бродяга, Ты же видел моря и метели. Как сменялись короны и стяги, Как эпохи стрелою летели. - Этот мир — это крылья и горы, Снег и пламя, любовь и тревоги, И бескрайние. . .
PowerShell Snippets
iNNOKENTIY21 11.11.2025
Модуль PowerShell 5. 1+ : Snippets. psm1 У меня модуль расположен в пользовательской папке модулей, по умолчанию: \Documents\WindowsPowerShell\Modules\Snippets\ А в самом низу файла-профиля. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru