Задать вопрос

Как передать props через react router?

Доброго времени суток. Изучаю React и начал изучать react-router v4. У меня есть wrapper component в середине которого есть пути для компонентов
const User = props => (
  <Wrapper {...props}>
      <Route path='/users/:id' component={AboutComponent} exact />
      <Route path='/users/:id/photos' component={PhotosComponent} />
      <Route path='/users/:id/friends' component={FriendsComponent} />
  </Wrapper>
);

Компоненты подгружаю через Loadable
const Loading = () => <div>Loading...</div>;

const AboutComponent = Loadable({
  loader: () => import('./About'),
  loading: Loading
});

const PhotosComponent = Loadable({
  loader: () => import('./Photos'),
  loading: Loading
});

const FriendsComponent = Loadable({
  loader: () => import('./Friends'),
  loading: Loading
});

Вот код для Wrapper component
render() {
    const childrenWithProps = React.Children.map(this.props.children, child => {
      return React.cloneElement(child, { user: 'Elon Musk' });
    });

    console.log(childrenWithProps);
    return (
      <div id="wrapper">
        <div className="row">
          <div className="col-lg-3 ">
            <img
              className="img-fluid"
              src="/avatar-2.jpg"
              alt="Elon Musk" />
          </div>
          <div className="col-lg-9 user-info">
            <h2>Elon Musk</h2>
            <nav>
              <Link to={`/users/${this.props.user.id}`} exact>
                About
              </Link>
              <span className="mx-1"></span>
              <Link to={`/users/${this.props.user.id}/photos`}>
                Photos
              </Link>
              <span className="mx-1"></span>
              <Link to={`/affiliates/users/${this.props.user.id}/friends`}>
                Friends
              </Link>
            </nav>
          </div>
        </div>
        {childrenWithProps}
      </div>
    );
  }

Если вывести childrenWithPropsнету и есть только match, location. Может кто-то сталкивался с такой проблемой и знает как решить. Спасибо
  • Вопрос задан
  • 1144 просмотра
Подписаться 1 Простой Комментировать
Решения вопроса 1
Пригласить эксперта
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Похожие вопросы