首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >Redux -尝试向configureStore添加一个函数

Redux -尝试向configureStore添加一个函数
EN

Stack Overflow用户
提问于 2020-01-17 10:14:27
回答 2查看 3.3K关注 0票数 8

我正在尝试将我的redux持久化到localStorage,但我不知道如何将它添加到redux-工具箱的configureStore函数中。

错误:

类型'{ reducer:{ progress: Reducer;};persistedState: any;}‘的persistedState参数不能分配给'ConfigureStoreOptions<{位移量: number;},AnyAction>’的参数。对象文字只能指定已知的属性,并且'persistedState‘在'ConfigureStoreOptions<{ AnyAction: number;},AnyAction>’类型中不存在。

代码:

localStorage.ts

代码语言:javascript
复制
export const loadState = () => {
  try {
    const serializedState = localStorage.getItem("state");
    if (serializedState === null) {
      return undefined;
    }
    return JSON.parse(serializedState);
  } catch (err) {
    return undefined;
  }
};

index.tsx

代码语言:javascript
复制
import React from "react";
import ReactDOM from "react-dom";
import App from "./App";
import counterSlice from "./store/reducers/counterSlice";
import { configureStore } from "@reduxjs/toolkit";
// import throttle from "lodash.throttle";
import { Provider } from "react-redux";
import { loadState, saveState } from "./store/localStorage";

const reducer = {
  progress: counterSlice
};
const persistedState = loadState();
const store = configureStore({
  reducer,
  persistedState
});

store.subscribe(() => {
  saveState({
    progress: store.getState().progress
  });
});

ReactDOM.render(
  <Provider store={store}>
    <App />
  </Provider>,
  document.getElementById("root")
);
EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2020-01-17 18:01:25

我是Redux工具包的创建者。persistedState不是configureStore的有效配置选项。The correct field name is preloadedState

票数 9
EN

Stack Overflow用户

发布于 2020-01-17 10:42:26

不要使用configureStore,而是使用createStore。对我来说,这是可行的:

代码语言:javascript
复制
const store = createStore(
    reducer,
    persistedState
  );

完整的例子:

代码语言:javascript
复制
  const loadFromLocalStorage = () => {
    try {
      const serializedState = localStorage.getItem('state');
      return JSON.parse(serializedState);
    } catch (e) {
      throw new Error(e)
    }
  };

  const saveToLocalStorage = state => {
    try {
      const serializedState = JSON.stringify(state);
      localStorage.setItem('state', serializedState);
    } catch (e) {
      throw new Error(e)
    }
  };

  const state= loadFromLocalStorage();


  const store = createStore(
    reducer,
    state
  );
  store.subscribe(() => {
    saveToLocalStorage(store.getState());
  });
票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/59785287

复制
相关文章

相似问题

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