07-React路由的使用

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>
  <!-- 容器,通过 React 渲染得到的 虚拟DOM,会呈现到这个位置 -->
  <div id="app"></div>
</body>

</html>

(2)main.js:

(3)app.jsx:

(4)ReactDemo/src/components/Home.jsx

(5)ReactDemo/src/components/Movie.jsx

(6)ReactDemo/src/components/About.jsx

运行结果:

20190214_1000.png

匹配路由参数

模糊匹配与精准匹配

我们在上面的代码中,进一步修改。假设 Movie 这个组件修改成这种路由匹配方式:

上面这种匹配方式,也是可以成功匹配到的。这是为啥呢?

这是因为:默认情况下,路由中的匹配规则,是模糊匹配的。如果 路由可以部分匹配成功,就会展示这个路由对应的组件。

如果想让路由规则,进行精确匹配,可以为Route添加 exact 属性。比如下面这种写法,因为是开启了精准匹配,所以是匹配不到的:(无法匹配)

另外,如果要匹配参数,可以在匹配规则中,使用 : 修饰符,表示这个位置匹配到的是参数。举例如下:(匹配正常)

获取路由参数

继续修改上面的代码。如果我想在 Movie 组件中显示路由中的参数,怎么做呢?

我们可以通过 props.match.params获取路由中的参数。举例做法如下:

app.jsx中的匹配规则如下:

Moivie 组件的写法如下:

打印结果如下:

20190214_1030.png

工程文件:

2019-02-14-ReactDemo.zip

参考链接

Last updated