javascript - 使用 useEffect 更新 useReducer 的“状态”
问题描述
在我的应用程序中,我使用的是 React Hooks/Context API。现在,每当我的 Provider 组件挂载时,我需要将从 localStorage 获取的数据分配给 initialState.carts / state.carts。如果 useEffect 支持返回对象,这是可能的。但是不能在 useEffect 中返回对象!
现在我该如何解决这个问题?
代码如下,
const initialState = {
books: books,
carts: []
};
export const Context = createContext(initialState);
export const Provider = ({ children }) => {
const [state, dispatch] = useReducer(reducer, initialState);
useEffect(() => {
if (localStorage.getItem("carts") !== null) {
const fetchedCarts = JSON.parse(localStorage.getItem("carts"));
//Here I want to assign 'fetchedCarts' array items in 'state.carts' or 'initialState.carts'
}
});
解决方案
您必须调度一个操作来更新您的state
变量。
if (localStorage.getItem("carts") !== null) {
const fetchedCarts = JSON.parse(localStorage.getItem("carts"));
dispatch({ type: 'UPDATE', payload: fetchedCarts })
}
因此,您必须将此操作类型添加到您已在此处使用的减速器开关:
const [state, dispatch] = useReducer(reducer, initialState);
减速器结构示例:
const reducer = (state, action) => {
switch (action.type) {
case 'UPDATE':
return { ...state, ...action.payload }
break
default:
return state
}
}
我相信useEffect()
应该有一个依赖数组(因为更新state
会以当前形式重新触发它)。
如果 useEffect 支持返回对象,这是可能的。但是不能在 useEffect 中返回对象!
来自 useEffect 的响应应该是一个函数(在卸载组件之前调用该函数) - 在此处返回一个对象将是一个错误。
推荐阅读
- c - 在 C 程序的 main 函数中访问 argc
- r - 为什么 anomalize::time_decompose() 的输出包含“median_spans”列而不是趋势列?
- python - 如何在numpy python中有效地为直线上的所有像素着色
- java - 为什么它会运行?
- r - 如何将带有 plotly 的 ggplot 嵌入到 rshiny 应用程序或 flexdashboard 中?
- twilio - 如何按属性启用自动回答插件
- ansible - 从 csv 注册条件时的 Ansible
- sql - 使用映射数据流连接多个源
- node.js - 使用 NodeJS 写入 JSON 时如何忽略空值或空白值
- python - 如何使用 Python 和 Panda 将此嵌套的 json 转换为 CSV?