React-Router只有一个孩子


71

我不断收到错误:

“路由器”可能只有一个子元素

使用react-router时。

我似乎无法弄清楚为什么它不起作用,因为它与示例中显示的代码完全一样:快速入门

这是我的代码:

import React from 'react';
import Editorstore from './Editorstore';
import App from './components/editor/App';
import BaseLayer from './components/baselayer';
import {BrowserRouter as Router, Route} from 'react-router-dom';
import {render} from 'react-dom';

const root = document.createElement('div');
root.id = 'app';
document.body.appendChild(root);

const store = new Editorstore();
const stylelist = ['https://maxcdn.bootstrapcdn.com/font-awesome/4.6.3/css/font-awesome.min.css', 'https://cdnjs.cloudflare.com/ajax/libs/semantic-ui/2.2.2/semantic.min.css', 'https://cdnjs.cloudflare.com/ajax/libs/animate.css/3.5.2/animate.min.css', 'https://api.tiles.mapbox.com/mapbox-gl-js/v0.33.1/mapbox-gl.css'];

stylelist.map((link) => {
    const a = document.createElement('link');
    a.rel = 'stylesheet';
    a.href = link;
    document.body.appendChild(a);
    return null;
});

render((
  <Router>
    <Route exact  path="/" component={BaseLayer} />
    <Route path="/editor" component={App} store={store} />
  </Router>
), document.querySelector('#app'));

感谢您的帮助


物联网(LinkRoute)内BrowserRouter需要进行内部的包裹div
onmyway133

Answers:


145

您必须将您Route的换行到<div>(或<Switch>)中。

render((
  <Router>
    <Route exact  path="/" component={BaseLayer} />
    <Route path="/editor" component={App} store={store} />
  </Router>
), document.querySelector('#app'));

应该

render((
  <Router>
    <div>
       <Route exact  path="/" component={BaseLayer} />
       <Route path="/editor" component={App} store={store} />
    </div>
  </Router>
), document.querySelector('#app'));

jsfiddle / webpackbin


24
奇怪。为什么是这样?
cameronroe

2
Router预计this.props.childrennull或以具有长度等于1
的QoP

1
这不起作用,它只在同一位置显示两条路线。
NSCoder

4
它显示两条路线,因为它使用div,您实际上应该使用switch。这使得路线独家 github.com/ReactTraining/react-router/blob/master/packages/...
唐D-JOE

有一个组件可以执行此包装:Switch
Adriano Godoy

38

这是中的API更改react-router 4.x。推荐的方法是将Routes包装在中Switch https //github.com/ReactTraining/react-router/issues/4131#issuecomment-274171357

报价单:

兑换

<Router>
  <Route ...>
  <Route ...>
</Router>

<Router>
  <Switch>
    <Route ...>
    <Route ...>
  </Switch>
</Router>

当然,您将需要添加Switch到导入中:

import { Switch, Router, Route } from 'react-router'

1
我遇到了Uncaught ReferenceError:使用Switch时未定义Switch错误
NSCoder

4
@NSCoder确保您使用的模块4.x.x版本react-routerrequireimport Switch位于模块顶部
FeifanZ

1
如果我在V-4中使用了开关,则说“Warning: Failed prop type: The prop 历史记录”已标记为必需Router,但其值为undefined.`
MD Ashik

3

我总是在React Web和Native(> = react 16)中使用Fragment

import React, { Component, Fragment } from 'react'
import { NativeRouter as Routes, Route, Link } from 'react-router-native'
import Navigation from './components/navigation'    
import HomeScreen from './screens/home'
import { RecipesScreen } from './screens/recipe'

class Main extends Component {
  render() {
    return (
      <Fragment>
        <Navigation />
        <Routes>
          <Fragment>
            <Route exact path="/" component={HomeScreen} />
            <Route path="/recipes" component={RecipesScreen} />
          </Fragment>
        </Routes>
      </Fragment>
    )
  }
}

export default Main

2

我将所有<Route />标签放入<Switch> </Switch>标签中,如下所示。

    <BrowserRouter>
        <Switch>
            <Route path='/' component={App} exact={true} /> 
            <Route path='/form-example' component={FormExample} />
        </Switch>
    </BrowserRouter>

这样就解决了问题。


1

如果要在路由器中嵌套其他组件,则应该这样做。

  <Router>
     <div>
       <otherComponent/>
         <div>
           <Route/>  
           <Route/>
           <Route/>
           <Route/>
         </div>
      </div>
    </Router>

1

如果您使用的是到达路由器,请确保代码如下所示:

<Router>
    <Login path="/" />
    <Login path="/login" />
</Router>

DivReact Router的情况下,将这些组件包括在内将可以完成此工作,但在Reach Routers中,请删除该Div元素。


0

您还可以将所有路线包裹在默认为索引页面的父路线中

<Router history={history}>    
   <Route path="/" component={IndexPage}>
      <Route path="to/page" component={MyPage}/>
      <Route path="to/page/:pathParam" component={MyPage}/>
   </Route>    
</Router>

0

我正在使用react-router-dom带有版本的软件包,5.0.1它与您的代码完美配合。

import { BrowserRouter as Router , Router, Link } from 'react-router-dom';
import Home from './pages/Home';
import About from './pages/About';
...

class App extends React.Component {
  render() {
    return (
      <Router>
        <ul>
          <li><Link path='/'>Home</Link></li>
          <li><Link path='/about'>About</Link></li>
        </ul>
        <Route path='/' exact component={Home} />
        <Route path='/about' component={About} />
      </Router>
    );
  }
}

export default App;

0

不知道我的路由器是否太简单,或者是否对此规则进行了更改,但是遵循的教程中提到了此限制(“路由器”可能只有一个子元素),它允许我添加3条路由而没有给出任何错误。这是工作代码:

function render() {
  ReactDOM.render(
    <BrowserRouter>
      <Route exact path="/" component={App} />
      <Route path="/add" component={AddAuthorForm} />
      <Route path="/test" component={test} />
    </BrowserRouter>
    ,
    document.getElementById('root')
  );
}

这是我的依赖项:

"react": "^16.13.1",
"react-dom": "^16.13.1",
"react-router-dom": "^5.1.2",
"react-scripts": "3.4.1",

-1

出现此问题时,你没有父标签之前<Route>里面<Router>这样来解决这一问题保持<Route>封闭在一个父标签如<div><p>等为例-

<Router>
    <p>
       <Route path="/login" component={Login} />
       <Route path="/register" component={Register} />
    </p>
</Router>

1
大多数情况下,将<p>添加为路由父级会使其成为无效的html,例如,在<p>中不能包含<div>
borisrorsvort
By using our site, you acknowledge that you have read and understand our Cookie Policy and Privacy Policy.
Licensed under cc by-sa 3.0 with attribution required.