首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何使用localStorage与useReducer挂钩?

如何使用localStorage与useReducer挂钩?
EN

Stack Overflow用户
提问于 2021-12-05 06:27:13
回答 1查看 440关注 0票数 0

我有一个todo应用程序,是用useReducer创建的,我需要将它们保存到localStorage中,但是我得到了一个error.What可能出错了吗?

代码语言:javascript
复制
const [{ todos, todoCount }, dispatch] = useReducer(
    reducer,
    {
      todos: [],
      todoCount: 0
    },
    (initial) => JSON.parse(localStorage.getItem("todos")) || initial
  );
 
  useEffect(() => {
    localStorage.setItem("todos", JSON.stringify(todos));
  }, [todos]);

我得到了这个错误:抛出了一个跨源错误。React无法访问开发中的实际错误对象。有关详细信息,请参阅https://reactjs.org/link/crossorigin-error

当我用useReducer编写一个简单的计数器应用程序时,我保存到localStorage的方式与此相同,但它不起作用

EN

回答 1

Stack Overflow用户

发布于 2021-12-05 07:00:27

需要使用useContext+useReducer+localStorage:

代码语言:javascript
复制
 const initialState = {
    todos:
      localStorage.getItem("todos") == null
        ? []
        : JSON.parse(localStorage.getItem("todos"))
  };
  const [{ todos }, dispatch] = useReducer(
    reducer,
    /* {
      todos: [],
      todoCount: 0
    }*/
    initialState
  );
  useEffect(() => {
    localStorage.setItem("todos", JSON.stringify(todos));
  }, [todos]);

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/70231972

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档