反应Redux路由问题

时间:2020-03-01 08:50:13

标签: javascript reactjs redux

我最近在使用React Router和Redux时遇到了一些问题。基本上,我有一个redux值集,让我知道是否选择了一个项目。如果选择该项,则将允许使用URL。我注意到的一件事。如果我添加了重定向功能。它破坏了一切

身份验证功能:

import React, { Component, Fragment } from "react";
import { Provider } from "react-redux";
// import store from "./store";
import {
  BrowserRouter as Router,
  Switch,
  Route,
  Redirect
} from "react-router-dom";
import { connect } from "react-redux";
import Profile from "./Profile";
import AddDomain from "./AddDomain";
import ChoosePackage from "./ChoosePackage";
import DashboardHome from "./DashboardHome";
import { Elements } from "@stripe/react-stripe-js";
import PropTypes from "prop-types";
import { loadStripe } from "@stripe/stripe-js";
const stripePromise = loadStripe("pk_test_7S0QSNizCdsJdm9yYEoRKSul00z4Pl6qK6");
class index extends Component {
  componentDidMount() {
    console.log("DOMAIN NAME" + this.props.domain_name);
  }
  state = {
    domain_name: ""
  };
  static propTypes = {
    domain_name: PropTypes.string.isRequired
  };
  domainCheck = () => {
    if (this.props.domain_name != "") {
      return <ChoosePackage />;
    } else {
      console.log("running rediect");
      return <Redirect to="/dashboard" />;
    }
  };
  render() {
    return (
      <React.Fragment>
        <Route path="/dashboard/add-domain/choose-package">
          {this.domainCheck()}
        </Route>
        <Route exact path="/dashboard/add-domain">
          <AddDomain />
        </Route>
        <Route exact path="/dashboard/profile">
          <Profile />
        </Route>
        <Route exact path="/dashboard">
          <DashboardHome />
        </Route>
      </React.Fragment>
    );
  }
}

const mapStateToProps = state => ({
  domain_name: state.domain.domain_name
});
index.defaultProps = {
  domain_name: ""
};
export default connect(mapStateToProps, { pure: false })(index);

非常感谢您的帮助

0 个答案:

没有答案