类型错误:无法读取未定义的 nexjs reudux 和 PersistGate 的属性“getState”

时间:2021-07-18 05:38:15

标签: reactjs redux next.js

错误类型错误:无法读取未定义的属性 'getState' 我尝试从 Create React App 迁移但无法使用 redux 我尝试了很多方法但仍然无法修复它。 -------------------------------------------------- -------------------------------------------------- -------------------------------------------------- -------------------------->

Error Image _app.js

import "../styles/globals.css";
import App from "next/app";
import { Provider } from "react-redux";
import React from "react";
import reduxStore from "../redux/store/store";
import { reduxPersistor} from "../redux/store/store";
import { PersistGate } from "redux-persist/integration/react";
import { appWithTranslation } from "next-i18next";
import theme from "../theme";
import { ThemeProvider } from "@material-ui/core/styles";
import Layout from "../components/layouts/Layout";
import { Provider as AlertProvider } from "react-alert";
import AlertTemplate from "../components/alert/alert.component.jsx";
import dynamic from "next/dynamic";
import withRedux from "next-redux-wrapper";
const Pace = dynamic(
  () => {
    return import("../components/customs/pace/pace.js");
  },
  { ssr: false }
);
class MyApp extends App {
  static async getInitialProps({ Component, ctx }) {
    return {
      pageProps: {
        // Call page-level getInitialProps
        ...(Component.getInitialProps
          ? await Component.getInitialProps(ctx)
          : {}),
      },
    };
  }
  componentDidMount() {
    // let app = databaserealtime.ref("/maintenance/maintenancestatus");
    // app.on("value", (snapshot) => {
    //   this.setState({
    //     maintenancestatus: snapshot.val(),
    //   });
    // if (snapshot.val() === 1) {
    this.unsubscribeFromAuth = auth.onAuthStateChanged(async (userAuth) => {
      this.setState({ currentUser: userAuth });
      if (userAuth) {
        const userRef = await createUserProfileDocument(userAuth);
        userRef.onSnapshot((snapShot) => {
          this.props.setCurrentUser({
            id: snapShot.id,
            ...snapShot.data(),
          });
        });
      }
    });
    // }
    // });
    // this.props.i18n.changeLanguage(this.props.lang);

    // this.unsubscribeFromAnnounce = this.getAnnounceText();
  }
  componentWillUnmount() {
    this.unsubscribeFromAuth && this.unsubscribeFromAuth();
    // this.unsubscribeFromAnnounce && this.unsubscribeFromMaintenanceStatus();
    // this.unsubscribeFromAnnounce && this.unsubscribeFromAnnounce();
    // this.unsubscribeFromAnnounce && this.getAnnounceText();
  }
  render() {
    const { Component, pageProps, store } = this.props;
    const options = {
      timeout: 10000,
    };
    return (
      <React.Fragment>
        <Provider store={store}>
          <PersistGate loading={null} persistor={reduxPersistor}>
            <ThemeProvider theme={theme}>
              <Pace color={theme.palette.primary.main} />
              <AlertProvider template={AlertTemplate} {...options}>
                <Layout>
                  <Component {...pageProps} />
                </Layout>
              </AlertProvider>
            </ThemeProvider>
          </PersistGate>
        </Provider>
      </React.Fragment>
    );
  }
}
// const mapStateToProps = ({ user, language }) => ({
//   currentUser: user.currentUser,
//   lang: language.lang,
// });
const mapStateToProps = (state) => console.log(state);
const mapDispatchToProps = (dispatch) => ({
  setCurrentUser: (user) => dispatch(setCurrentUser(user)),
  setI18n: (lang) => dispatch(setI18n(lang)),
});
export default withRedux(
  mapStateToProps,
  mapDispatchToProps,
)(appWithTranslation(MyApp));

store.js

import { createStore, applyMiddleware } from "redux";
import { createLogger } from "redux-logger";
import rootReducer from "../root-reducer";
import { persistStore } from "redux-persist";
import { composeWithDevTools } from 'redux-devtools-extension';
const logger = createLogger();
let middleware = [];
if (process.env.NODE_ENV === "development") {
  middleware = [...middleware, logger];
} else {
  middleware = [...middleware];
}

export const reduxStore = createStore(rootReducer, composeWithDevTools(applyMiddleware(...middleware)));
export const reduxPersistor = persistStore(reduxStore,{});

root-reducer.js

import { combineReducers } from "redux";
import { persistReducer } from "redux-persist";
import storage from "redux-persist/lib/storage";
import userReducer from "./user/user.reducer";
import i18nReducer from "./i18n/i18n.reducer";
import currencyReducer from "./currency/currency.reducer";
const persistConfig = {
  key: "root",
  storage,
  whitelist: ["language", "currency"],
};
const rootReducer = combineReducers({
  user: userReducer,
  language: i18nReducer,
  currency: currencyReducer,
});
export default persistReducer(persistConfig, rootReducer);

1 个答案:

答案 0 :(得分:0)

尝试在 provider 中将 store 更改为 reduxStore 因为您从 "../redux/store/store" 导入 reduxStore 但 store 只是道具中未定义的