私はReact JSの初心者であり、ダッシュボード用のリアクションルーターベースのナビゲーションを開発したいと考えています。モックアップは次のとおりです。
ルーティングを試みるために作成したapp.jsコードは次のとおりです。
import React from 'react'
import { render } from 'react-dom'
import { Router, Route, Link } from 'react-router'
import Login from './components/Login.js';
const App = React.createClass({
render() {
return (
<div>
<h1>App</h1>
<ul>
<li><Link to="/login">Login</Link></li>
<li><Link to="/inbox">Inbox</Link></li>
</ul>
{this.props.children}
</div>
)
}
})
render((
<li>
<Router>
<Route path="/" component={App}>
<Route path="login" component={Login} />
</Route>
</Router>
</li>
), document.getElementById('placeholder'))
モックアップに示されているナビゲーションを作成するにはどうすればよいですか?
はい、ダニエルは正しいですが、彼の答えを拡張するには、主要なアプリコンポーネントにnavbarコンポーネントが必要です。そのようにして、プライマリアプリ(「/」パスの下の任意のページ)をレンダリングすると、ナビゲーションバーも表示されます。ログインページにnavbarを表示したくないので、ネストされたコンポーネントではなく、それ自体である必要があります。したがって、ルートは次のようになります。
<Router>
<Route path="/" component={App}>
<Route path="page1" component={Page1} />
<Route path="page2" component={Page2} />
</Route>
<Route path="/login" component={Login} />
</Router>
そして、他のコンポーネントは次のようになります。
var NavBar = React.createClass({
render() {
return (
<div>
<ul>
<a onClick={() => history.Push('page1') }>Page 1</a>
<a onClick={() => history.Push('page2') }>Page 2</a>
</ul>
</div>
)
}
});
var App = React.createClass({
render() {
return (
<div>
<NavBar />
<div>Other Content</div>
{this.props.children}
</div>
)
}
});
注受け入れられたものはまったく問題ありませんが、バージョン4の例は十分に異なるため追加したいと考えました。
import React from 'react';
import { Link } from 'react-router';
export default class Nav extends React.Component {
render() {
return (
<nav className="Nav">
<div className="Nav__container">
<Link to="/" className="Nav__brand">
<img src="logo.svg" className="Nav__logo" />
</Link>
<div className="Nav__right">
<ul className="Nav__item-wrapper">
<li className="Nav__item">
<Link className="Nav__link" to="/path1">Link 1</Link>
</li>
<li className="Nav__item">
<Link className="Nav__link" to="/path2">Link 2</Link>
</li>
<li className="Nav__item">
<Link className="Nav__link" to="/path3">Link 3</Link>
</li>
</ul>
</div>
</div>
</nav>
);
}
}
import React from 'react';
import { Link, Switch, Route } from 'react-router';
import Nav from './nav';
import Page1 from './page1';
import Page2 from './page2';
import Page3 from './page3';
export default class App extends React.Component {
render() {
return (
<div className="App">
<Router>
<div>
<Nav />
<Switch>
<Route exactly component={Landing} pattern="/" />
<Route exactly component={Page1} pattern="/path1" />
<Route exactly component={Page2} pattern="/path2" />
<Route exactly component={Page3} pattern="/path3" />
<Route component={Page404} />
</Switch>
</div>
</Router>
</div>
);
}
}
あるいは、より動的なナビゲーションが必要な場合は、優れたv4ドキュメントを参照できます。 https://reacttraining.com/react-router/web/example/sidebar
ログインページなど、Navのないページについて尋ねた人が数人います。私は通常、ラッパーのルートコンポーネントでそれにアプローチします
import React from 'react';
import { Link, Switch, Route } from 'react-router';
import Nav from './nav';
import Page1 from './page1';
import Page2 from './page2';
import Page3 from './page3';
const NavRoute = ({exact, path, component: Component}) => (
<Route exact={exact} path={path} render={(props) => (
<div>
<Header/>
<Component {...props}/>
</div>
)}/>
)
export default class App extends React.Component {
render() {
return (
<div className="App">
<Router>
<Switch>
<NavRoute exactly component={Landing} pattern="/" />
<Route exactly component={Login} pattern="/login" />
<NavRoute exactly component={Page1} pattern="/path1" />
<NavRoute exactly component={Page2} pattern="/path2" />
<NavRoute component={Page404} />
</Switch>
</Router>
</div>
);
}
}