LocalStorage Dispapers после обновления. Массив сбрасывает [дублировать]Javascript

Форум по Javascript
Ответить
Anonymous
 LocalStorage Dispapers после обновления. Массив сбрасывает [дублировать]

Сообщение Anonymous »

Я следил за учебником проекта React и писал тот же код до последнего бита, но заметил, что, хотя любимые фильмы будут сохранены в LocalStorage, при обновлении массив будет сброшен. Затем я заметил ошибку «moviecontext.jsx (файл с кодом LocalStorage) не перезагружается непосредственно перед журналами любимых фильмов, сохраненных в LocalStorage до обновления. < /P>
import { createContext, useState, useContext, useEffect } from "react";

const MovieContext = createContext()

export const useMovieContext = () => useContext(MovieContext);

export const MovieProvider = ({children}) => {
const [favorites, setFavorites] = useState([]);

useEffect(() => {
console.log('useEffect on mount runs');
const storedFavs = localStorage.getItem("favorites");
console.log('storedFavs', storedFavs);

if (storedFavs) {
try {
setFavorites(JSON.parse(storedFavs));
} catch (err) {
console.error('Failed to load from localStorage...', err);
}
}
}, []);

useEffect(() => {
try {
localStorage.setItem("favorites", JSON.stringify(favorites));
console.log('Saving to localStorage', favorites);
} catch (error) {
console.error('Failed to save to localStorage', error);

}
}, [favorites]);

const addToFavorites = (movie) => {
setFavorites(prev => [...prev, movie]);
}

const removeFromFavorites = (movieId) => {
setFavorites(prev => prev.filter(movie => movie.id !== movieId));
}

const isFavorite = (movieId) => {
return favorites.some(movie => movie.id === movieId);
}

const value = {
favorites,
addToFavorites,
removeFromFavorites,
isFavorite
}

return
{children}

}
< /code>
app.jsx имела обертку MovieProvider: < /p>
import "./css/App.css";
import Favorites from "./pages/Favorites";
import Home from "./pages/Home";
import { Routes, Route } from "react-router-dom";
import { MovieProvider } from "./contexts/MovieContext";
import NavBar from "./components/NavBar";

function App() {
return (









);
}

export default App;



Подробнее здесь: https://stackoverflow.com/questions/796 ... ray-resets
Ответить

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

Вернуться в «Javascript»