首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >TypeError: this.props.persistor.subscribe不是函数Redux Persist

TypeError: this.props.persistor.subscribe不是函数Redux Persist
EN

Stack Overflow用户
提问于 2018-03-25 05:55:16
回答 2查看 1.6K关注 0票数 0

我正在将redux-persist合并到我的react应用程序中,并且收到以下错误: TypeError: this.props.persistor.subscribe不是一个函数

我正在遵循以下链接中描述的相同文档:https://www.npmjs.com/package/redux-persist

store.js

代码语言:javascript
复制
import {applyMiddleware,createStore,combineReducers} from "redux"
import {createLogger} from "redux-logger"
import thunk from "redux-thunk"
import promise from "redux-promise-middleware"
import { persistStore, persistReducer } from 'redux-persist'
import storage from 'redux-persist/lib/storage' // defaults to localStorage for web and AsyncStorage for react-native

import reducer from "./Reducers"
const middleware = applyMiddleware(promise(),thunk,createLogger())
const persistConfig = {
  key: 'root',
  storage,
}
const persistedReducer = persistReducer(persistConfig, reducer)

export default () => {
  let store = createStore(persistedReducer,middleware)
  let persistor = persistStore(store)
  return { store, persistor }
}.js:

index.js

代码语言:javascript
复制
import React from 'react';
import ReactDOM from 'react-dom';
import './index.css';
import App from './App';
import MuiThemeProvider from 'material-ui/styles/MuiThemeProvider';
import registerServiceWorker from './registerServiceWorker';
import { Provider } from 'react-redux'
import store from "./store"
import persistor from "./store"

import { PersistGate } from 'redux-persist/integration/react'

ReactDOM.render(
    <PersistGate loading={null} persistor={persistor}>
        <Provider store={store}>
                <MuiThemeProvider>
                    <App />
                </MuiThemeProvider>
        </Provider>
    </PersistGate>,


    document.getElementById('root'));
registerServiceWorker();
EN

回答 2

Stack Overflow用户

发布于 2018-08-29 02:57:21

import {store, persistor} from 'your-store-module'绝对是正确的导入语法。

我建议仔细检查您的导出语句和路径。

票数 0
EN

Stack Overflow用户

发布于 2020-02-20 18:47:24

只需像这样导出你的store和persitor:

代码语言:javascript
复制
export default {store, persistor};

然后在reducer上像这样导入它(其中定义了storepersistor ):

代码语言:javascript
复制
import Store from 'yourModuleName'

最后,调用persistorstore并将PersistGate放入Provider中,如下所示:

代码语言:javascript
复制
<Provider store={Store.store}>
     <PersistGate loading={null} persistor={Store.persistor}>
         <MuiThemeProvider>
            <App />
         </MuiThemeProvider>
     </PersistGate>,
</Provider>
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/49470349

复制
相关文章

相似问题

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