75 votes

React-Router un seul enfant

Je continue à avoir l'erreur:

Un 'routeur' ne peut avoir qu'un seul élément enfant

en utilisant react-router.

Je n'arrive pas à comprendre pourquoi cela ne fonctionne pas, car c'est exactement le code qu'ils montrent dans leur exemple: https://reacttraining.com/react-router/web/guides/quick-start

Voici mon code:

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

Merci pour ton aide

151voto

QoP Points 12702

Vous devez envelopper vos Route dans un <div> (ou un <Switch> ).

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

devrait être

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

jsfiddle / webpackbin

40voto

FeifanZ Points 9348

C'est une API de changement en react-router 4.x. Approche recommandée consiste à envelopper Routes en Switch: https://github.com/ReactTraining/react-router/issues/4131#issuecomment-274171357

Citant:

Convertir

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

pour

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

Vous aurez, bien sûr, besoin d'ajouter Switch de vos importations:

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

3voto

White Rabbit Points 142

J'utilise toujours Fragment dans les sites web et natifs (> = 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
 

2voto

Vishal Shetty Points 340

Je mets tout mon <Route /> balises à l' intérieur du <Switch> </Switch> étiquette comme celui - ci.

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

Cela résout le problème.

1voto

Chawki Points 69

Si vous imbriquez d'autres composants dans le routeur, procédez comme suit.

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

Prograide.com

Prograide est une communauté de développeurs qui cherche à élargir la connaissance de la programmation au-delà de l'anglais.
Pour cela nous avons les plus grands doutes résolus en français et vous pouvez aussi poser vos propres questions ou résoudre celles des autres.

Powered by:

X