React页面路由

本文详细介绍了React中的页面路由,包括hash模式和history模式的特点及API使用。重点讲解了react-router-dom模块,涵盖安装、HashRouter和BrowserRouter组件、Route组件的路径映射、Link和NavLink组件的用法、Redirect组件实现页面重定向、Switch组件的路由切换功能以及withRouter组件的使用,并提及404视图的处理。
摘要由CSDN通过智能技术生成

目录

一、页面路由

1、页面路由的方式

二、React的页面路由模块

1、安装:npm install react-router-dom

2、实现路由模式的组件(最外层):决定路由模式

3、Route组件:实现路径和显示组件之间的映射

4、Router组件

5、Link和NavLink组件:类似于标签

6、Redirect组件:页面重定向。属性和Link相同

7、Switch组件:进行路由切换。类似Tab标签

8、withRouter组件

9、404视图


一、页面路由

1、页面路由的方式

(1)hash模式:在url后面带#

这里的 hash 就是指 url 尾巴后的 # 号以及后面的字符。这里的 # 和 css 里的 # 是一个意思。hash也称作锚点,本身是用来做页面定位的,她可以使对应 id 的元素显示在可视区域内。

hash 本来是拿来做页面定位的,如果拿来做路由的话,原来的锚点功能就不能用了。

 缺点:传递参数的方式是在url后拼接,会有体积的限制

使用到的api:

  • window.location.hash = 'qq' // 设置 url 的 hash,会在当前url后加上 '#qq'

  • var hash = window.location.hash // '#qq'

  • window.addEventListener('hashchange', function(){

        // 监听hash变化,点击浏览器的前进后退会触发

    })

(2)history模式

  • 可以传递复杂的参数
  • 可以监听浏览器的前进、后退事件(back、forward、go)

hash 的传参是基于 url的,如果要传递复杂的数据,会有体积的限制,而history 模式不仅可以在url里放参数,还可以将数据存放在一个特定的对象中

 使用到的api

  • window.history.pushState(state, title, url)
  • state:需要保存的数据,这个数据在触发popstate事件时,可以在event.state里获取
  • title:标题,基本没用,一般传 null
  • url:设定新的历史记录的 url。新的 url 与当前 url 的 origin 必须是一樣的,否则会抛出错误。url可以是绝对路径,也可以是相对路径

 举例:

  • 当前url是 https://www.baidu.com/a/,执行history.pushState(null, null, './qq/'),则变成 https://www.baidu.com/a/qq/,执行history.pushState(null, null, '/qq/'),则变成 https://www.baidu.com/qq/
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值