title: 07-React路由的使用
publish: true
React路由的使用
使用React路由之前,我们需要先安装 react-router-dom
这个包。比如:
yarn add react-router-dom
|
代码举例:
(1)index.html
<!DOCTYPE html> <html lang="en">
<head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <meta http-equiv="X-UA-Compatible" content="ie=edge"> <title>Document</title> </head>
<body> <div id="app"></div> </body>
</html>
|
(2)main.js:
import React from "react"; import ReactDOM from "react-dom";
import App from "./App.jsx";
ReactDOM.render(<App />, document.getElementById("app"));
|
(3)app.jsx:
import React from "react";
import { HashRouter, Route, Link } from "react-router-dom";
import Home from "./components/Home.jsx"; import Movie from "./components/Movie.jsx"; import About from "./components/About.jsx";
export default class App extends React.Component { constructor(props) { super(props); this.state = {}; }
render() { return ( <HashRouter> <div> <h1>这是网站的APP根组件</h1> <hr />
<Link to="/home">首页</Link> <Link to="/movie">电影</Link> <Link to="/about">关于</Link> <hr />
{} {} {} <Route path="/home" component={Home} /> <hr /> <Route path="/movie" component={Movie} /> <hr /> <Route path="/about" component={About} /> </div> </HashRouter> ); } }
|
(4)ReactDemo/src/components/Home.jsx
import React from "react";
export default class Home extends React.Component { constructor(props) { super(props); this.state = {}; }
render() { return <div>Home组件</div>; } }
|
(5)ReactDemo/src/components/Movie.jsx
import React from "react";
export default class Movie extends React.Component { constructor(props) { super(props); this.state = {}; }
render() { return <div>Movie组件</div>; } }
|
(6)ReactDemo/src/components/About.jsx
import React from "react";
export default class About extends React.Component { constructor(props) { super(props); this.state = {}; }
render() { return <div>About组件</div>; } }
|
运行结果:
20190214_1000.png
匹配路由参数
模糊匹配与精准匹配
我们在上面的代码中,进一步修改。假设 Movie 这个组件修改成这种路由匹配方式:
<Link to="/movie/top250">电影</Link>
<Route path="/movie" component={Movie} />
|
上面这种匹配方式,也是可以成功匹配到的。这是为啥呢?
这是因为:默认情况下,路由中的匹配规则,是模糊匹配的。如果 路由可以部分匹配成功,就会展示这个路由对应的组件。
如果想让路由规则,进行精确匹配,可以为Route添加 exact
属性。比如下面这种写法,因为是开启了精准匹配,所以是匹配不到的:(无法匹配)
<Link to="/movie/top250/20">电影</Link>
<Route path="/movie/" component={Movie} exact/>
|
另外,如果要匹配参数,可以在匹配规则中,使用 :
修饰符,表示这个位置匹配到的是参数。举例如下:(匹配正常)
<Link to="/movie/top250/20">电影</Link>
<Route path="/movie/:type/:id" component={Movie} exact/>
|
获取路由参数
继续修改上面的代码。如果我想在 Movie 组件中显示路由中的参数,怎么做呢?
我们可以通过 props.match.params
获取路由中的参数。举例做法如下:
app.jsx中的匹配规则如下:
<Link to="/movie/top100/5">电影</Link>
<Route path="/movie/:type/:id" component={Movie} exact/>
|
Moivie 组件的写法如下:
import React from "react";
export default class Movie extends React.Component { constructor(props) { super(props); this.state = { routeParams: props.match.params }; }
render() { console.log(this); return ( <div> {} Movie --- {this.state.routeParams.type} --- {this.state.routeParams.id} </div> ); } }
|
打印结果如下:
20190214_1030.png
工程文件:
2019-02-14-ReactDemo.zip
参考链接