私はエラーを取得し続けます:
'ルーター'は一つの子要素しか持てません
react-routerを使うとき。
なぜこれがうまくいかないのか理解できないようです。なぜならそれは彼らの例で示しているコードと全く同じだからです。 https://reacttraining.com/react-router/web/guides /クイックスタート
これが私のコードです:
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'));
助けてくれてありがとう
あなたはあなたのRoute
name__を<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'));
これはreact-router
4.x
のAPIの変更点です。推奨される方法は、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'
反応ウェブとネイティブで常にフラグメントを使用します(> =反応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
このように、すべての<Route />
タグを<Switch> </Switch>
タグの内側に置きます。
<BrowserRouter>
<Switch>
<Route path='/' component={App} exact={true} />
<Route path='/form-example' component={FormExample} />
</Switch>
</BrowserRouter>
これで問題は解決します。
あなたがルーターの中に他のコンポーネントを入れ子にしているなら、あなたは好きになるべきです。
<Router>
<div>
<otherComponent/>
<div>
<Route/>
<Route/>
<Route/>
<Route/>
</div>
</div>
</Router>
すべてのルートを、デフォルトのインデックスページになる親ルートでラップすることもできます。
<Router history={history}>
<Route path="/" component={IndexPage}>
<Route path="to/page" component={MyPage}/>
<Route path="to/page/:pathParam" component={MyPage}/>
</Route>
</Router>