【发布时间】:2016-04-10 21:31:24
【问题描述】:
在这里学习 React 并尝试获取工作路线。这是一个非常简单的事情,只是为了了解语法等。下面的代码在我在地址栏中输入路线一和二时起作用。但我想建立一个导航栏。假设我可以简单地在 App.js 中添加 HTML 来完成此操作,我意识到使用 <a href= 不是使用 Link 的方法。这适用于我的路线中的<Link> 标签,但说我想向 App.js 添加一个导航,使用相同的链接方法不起作用。
我尝试添加:
<h1>
<Link to="/route-one">One</Link>
|
<Link to="/route-two">Two</Link>
</h1>
<hr />
<Router>
...
但“一”和“二”不是链接。虽然在浏览器控制台中我看到:
TypeError: this.context.history is undefined
我问过导师,但他不想帮忙。
请看下面我目前拥有的代码;
这是 App.js 文件:
import React from 'react';
import ReactDOM from 'react-dom';
import { Router, Route, IndexRoute } from 'react-router';
import RouteOne from './RouteOne.js';
import RouteTwo from './RouteTwo.js';
import { Link } from 'react-router';
const App = React.createClass({
render() {
return (
<div>
<Router>
<Route path="route-one" component={RouteOne} />
<Route path="route-two" component={RouteTwo} />
</Router>
</div>
)
}
});
ReactDOM.render(<App />, document.getElementById("app"));
这是 RouteOne.js:
import React from 'react';
import { Link } from 'react-router';
var RouteOne = React.createClass({
render() {
return (
<div>
<h2>Route One</h2>
<Link to="/route-two">
<h3>Switch Route</h3>
</Link>
</div>
)
}
});
export default RouteOne;
这是 RouteTwo.js:
import React from 'react';
import { Link } from 'react-router';
var RouteTwo = React.createClass({
render() {
return (
<div>
<h2>Route Two</h2>
<Link to="/route-one">
<h3>Switch Route</h3>
</Link>
</div>
)
}
});
export default RouteTwo;
【问题讨论】:
标签: javascript html reactjs react-router react-jsx