Маршрут Post ID отображается в других компонентах

#reactjs #redux #react-redux #redux-router

#reactjs #сокращение #реагировать-redux #redux-маршрутизатор

Вопрос:

Я изучаю router и redux. Я пытаюсь создать блог. Теперь маршрут идентификатора записи отображается в других компонентах, таких как About и portfolio, но не на домашней странице, потому что я указал для него точный путь.

https://github.com/chiranjeebhub/router-redux

Post.js:

 import React, { Component } from "react";
import { connect } from "react-redux";

class Post extends Component {
  render() {
    const post = this.props.post ? (
      <div>
        <h4>{this.props.post.title}</h4>
        <p>{this.props.post.body}</p>
      </div>
    ) : (
      <div>
        <p>loading post ... </p>
      </div>
    );
    return <div>{post}</div>;
  }
}

const mapStateToProps = (state, ownProps) => {
  let id = ownProps.match.params.post_id;
  return {
    post: state.posts.find(post => post.id == id)
  };
};

export default connect(mapStateToProps)(Post);
  

Мои маршрутизаторы:

 import React, { Component } from "react";
import { BrowserRouter, Route } from "react-router-dom";
import NavBar from "./Components/NavBar";
import Home from "./Components/Home";
import About from "./Components/About";
import Post from "./Components/post";
import Portfolio from "./Components/portfolio";

class App extends Component {
  render() {
    return (
      <BrowserRouter>
        <div className="App">
          <NavBar />
          <Route exact path="/" component={Home} />
          <Route path="/about" component={About} />
          <Route path="/portfolio" component={Portfolio} />
          <Route path="/:post_id" component={Post} />
        </div>
      </BrowserRouter>
    );
  }
}

export default App;
  

About.js

 import React, { Component } from "react";

class About extends Component {
  render() {
    return (
      <div>
        <h1>About Me</h1>
      </div>
    );
  }
}

export default About;

  

Редуктор

 const initState = {
  posts: [
    { id: "1", title: "title1", body: "body1" },
    { id: "2", title: "title2", body: "body2" },
    { id: "3", title: "title3", body: "body3" },
    { id: "4", title: "title4", body: "body4" }
  ]
};

const rootReducer = (state = initState, action) => {
  return state;
};

export default rootReducer;
  

Теперь, когда я загружаю компонент «About», отображается «Загрузка записей …» из post.js

Комментарии:

1. при загрузке появляется portfolio то же "Loading Posts..." ?

2. ДА. Он отображается в портфолио

Ответ №1:

У вас возникла проблема, потому что путь

 <Route path="/:post_id" component={Post} />
  

показывает, что в post_id заполнителе ожидается динамическое значение. As post_id — это просто заполнитель, использующий about , portfolio 1 и т.д. В качестве параметров маршрута, удовлетворяющих условию.

то есть

 // All of them are valid
/about
/portfolio
/1
  

Таким образом, Post компонент отображается вместе с другими компонентами.

Поэтому вы должны обернуть Route компоненты с помощью Switch Component. Поскольку Switch компонент отображает только первый дочерний элемент, соответствующий пути, Post компонент не будет отображаться при использовании /about и /portfolio .

 import { BrowserRouter, Route, Switch } from 'react-router-dom';

 <BrowserRouter>
    <div className="App">
      <NavBar />
      <Switch>
        <Route exact path="/" component={Home} />
        <Route path="/about" component={About} />
        <Route path="/portfolio" component={Portfolio} />
        <Route path="/:post_id" component={Post} />
      </Switch>
    </div>
  </BrowserRouter>