react-router-dom 路由安装和简单使用操作

一、安装

cnpm install react-router-dom --save

二、使用

1、hashRouter和BroswerRouter

 * HashRouter:锚点链接   地址中带#
 * BrowserRouter:h5新特性,history.push   地址中不带#,带/   上线之后需要后台做重定向处理,否则会出现404

在这里插入图片描述

2、exact:精准匹配

默认情况下,只要路径中从前往后完整的包含每一个路由,那么这个路由对应的页面就会显示出来

如:/mine/ucenter 中包含 /mine,则地址为 http://localhost:8000/#/mine/ucenter 时,二者对应的页面都会显示出来;如果地址为 http://localhost:8000/#/mine 时,只有后者对应的页面会显示出来
在这里插入图片描述

3、strict:精准匹配

strict 需要和 extract 一起使用,可以使得路由匹配更加精准

默认情况下,请求地址后面添加 / 并不会影响页面请求,如图
在这里插入图片描述

<BrowserRouter>
  <Nav />
  <Route exact path='/' component={Home}></Route>
  <Route exact path='/mine' component={Mine}></Route>
  <Route exact path='/mine/ucenter' component={UCenter}></Route>
  <Route exact path='/demo' render={(props) => <Demo {...props} name='你好' />}></Route>
</BrowserRouter>

但是,有些时候可能会有需求:添加 / 和不添加 / 为两个不同的地址。这时,就可以使用 strict 来处理
在这里插入图片描述

<BrowserRouter>
  <Nav />
  <Route exact path='/' component={Home}></Route>
  <Route exact strict path='/mine' component={Mine}></Route>
  <Route exact strict path='/mine/ucenter' component={UCenter}></Route>
  <Route exact strict path='/demo' render={(props) => <Demo {...props} name='你好' />}></Route>
</BrowserRouter>

4、Link

import React from 'react';
import { Link } from 'react-router-dom'

export default function Nav() {
  return (
    <div>
        <ul>
          <li>
            <Link to='/'>Home页面</Link>
            {/* <a href='/'>Home页面</a> */}
          </li>
          <li>
            <Link to='/mine'>Mine页面</Link>
          </li>
          <li>
            <Link to='/mine/ucenter'>UCenter页面</Link>
          </li>
          <li>
            <Link to='/demo'>Demo页面</Link>
          </li>
        </ul>
    </div>
  );
}

5、路由传参

参考另一篇文章:https://blog.csdn.net/qq_41956139/article/details/106587089

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值