首页 > 解决方案 > 为什么我的 React 组件在使用 React-Router 时不呈现?

问题描述

我已经在 App.js 中设置了我的 React 路由器。页面组件会渲染。当我点击一个链接时,页面组件将不会呈现,但浏览器中的 URL 会更改为“page/{id}”。为什么是这样?

页面组件:

function Pages(props) {   const managedPages = JSON.parse(localStorage.getItem("managedPages"));   console.log(managedPages);

  return (
    <div>
      <List>
        {managedPages.map(page => (
          <ListItem key={page.id}>
            <Link
              to={`/page/${page.id}`}
              style={{ textDecoration: "none", color: "black" }}
            >
              <ListItemText primary="Teszt Színház" />
            </Link>
          </ListItem>
        ))}
      </List>
      <Route path="/page" component={Page} />
    </div>   ); }

应用程序.js jsx:

 return (
<MuiPickersUtilsProvider utils={MomentUtils}>
        <BrowserRouter>
          <div className="App">
            <BarAndMenu
              userLoginAndDataDownloadCompletedOut={
                this.userLoginAndDataDownloadCompletedOut
              }
            />
          </div>
          <Switch>
            <Route path="/" exact component={OngoingEventList} />
            <Route path="/selectSeat" component={SelectSeat} />
            <Route path="/releasePurpose/:id" component={ReleasePurpose} />
            <Route
              path="/marketingResourceConfigurationAndResult/:id"
              component={MarketingResourceConfigurationAndResult}
            />
            <Route path="/myTickets" exact component={MyTicketList} />
            <Route path="/myTickets/:id" component={MyTicket} />
            <Route path="/auditoriumList/:id" component={AuditoriumSelector} />
            <Route path="/pages" component={Pages} />
          </Switch>
        </BrowserRouter>
</MuiPickersUtilsProvider utils={MomentUtils}>
    );

标签: reactjsreact-router

解决方案


这是因为/page/:idand/page是两种不同的模式,它们不匹配。

将您的 Route 定义更改为如下所示:

<Route path="/page/:id" component={Page} />

此外,您/page/pages路由中定义了路由,当您导航到/page:id. 因此,将路由定义从Pages组件中提取出来,它应该可以工作。

https://reacttraining.com/react-router/web/example/url-params


推荐阅读