Подтвердить что ты не робот

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'));

Спасибо за помощь

4b9b3361

Ответ 1

Вы должны обернуть 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

Ответ 2

Это изменение API в react-router 4.x Рекомендуемый подход состоит в том, чтобы обернуть Route в 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'

Ответ 3

Я всегда использую Фрагмент в вебе реакции и нативном (> = реагируйте 16)

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

Ответ 4

Я поместил все свои теги <Route/> тег <Switch> </Switch> следующим образом.

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

Это решает проблему.

Ответ 5

Если вы вкладываете другие компоненты в маршрутизатор, вы должны делать то же самое.

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

Ответ 6

Вы также можете обернуть весь свой маршрут в родительский маршрут, который по умолчанию имеет индексную страницу

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

Ответ 7

Я использую пакет 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;

Ответ 8

Эта проблема возникает, если у вас нет родительского тега до <Route> внутри <Router>, поэтому для решения этой проблемы сохраните <Route>, заключенный в родительский тег, например <div>, <p> и т.д. Пример -

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