HashRouter和 HistoryRouter的区别与原理

区别:

  1. history和hash都是利用浏览器的两种特性实现前端路由,history是利用浏览历史记录栈的API实现,hash是监听location对象hash值变化事件来实现
  2. history的url没有'#'号,hash反之
  3. 相同的url,history会触发添加到浏览器历史记录栈中,hash不会触发,history需要后端配合,如果后端不配合刷新新页面会出现404,hash不需要。

原理:
HashRouter的原理:
通过window.onhashchange方法获取新URL中hash值,再做进一步处理

HistoryRouter的原理:
通过history.pushState 使用它做页面跳转不会触发页面刷新,使用window.onpopstate 监听浏览器的前进和后退,再做其他处理

每当激活同一文档中不同的历史记录条目时,popstate 事件就会在对应的 window 对象上触发。如果当前处于激活状态的历史记录条目是由 history.pushState() 方法创建的或者是由 history.replaceState() 方法修改的,则 popstate 事件的 state 属性包含了这个历史记录条目的 state 对象的一个拷贝。

调用 history.pushState() 或者 history.replaceState() 不会触发 popstate 事件。popstate 事件只会在浏览器某些行为下触发,比如点击后退按钮(或者在 JavaScript 中调用 history.back() 方法)。即,在同一文档的两个历史记录条目之间导航会触发该事件。

另外:
hash模式下url会带有#,需要url更优雅时,可以使用history模式。
需要兼容低版本的浏览器时,建议使用hash模式。
需要添加任意类型数据到记录时,可以使用history模式。

延伸
前端路由的出现要从 ajax 开始,有了 Ajax 后,用户交互就不用每次都刷新页面,体验带来了极大的提升。随着技术的发展,简单的异步已经不能满足需求,所以异步的更高级体验出现了——SPA(单页应用)。 SPA 的出现大大提高了 WEB 应用的交互体验。在与用户的交互过程中,不再需要重新刷新页面,获取数据也是通过 Ajax 异步获取,页面显示变的更加流畅。 但由于 SPA 中用户的交互是通过 JS 改变 HTML 内容来实现的,页面本身的 url 并没有变化,这导致了两个问题:
• SPA 无法记住用户的操作记录,无论是刷新、前进还是后退,都无法展示用户真实的期望内容。
• SPA 中虽然由于业务的不同会有多种页面展示形式,但只有一个 url,对 SEO 不友好,不方便搜索引擎进行收录。
前端路由就是为了解决上述问题而出现。
(部分内容来自牛客)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
ReactHashRouterReact Router 提供的一种路由器类型,它使用 URL 的哈希(hash)来实现路由HashRouter原理是通过监听 URL 的哈希变化来确定当前的路由状态,并根据配置的路由规则将对应的组件渲染到页面上。 当使用 HashRouter 时,URL 的格式通常为 `http://example.com/#/path`,其中 `#/path` 是 URL 的哈希部分。通过这种方式,浏览器不会向服务器发送请求,而是仅仅改变 URL 的哈希部分,从而实现页面之间的切换。 下面是 HashRouter 的工作原理: 1. 初始化:当应用启动时,HashRouter 会监听 URL 的哈希变化,并根据当前的哈希值来确定初始路由状态。 2. 路由匹配:HashRouter 使用配置的路由规则来匹配当前的哈希值,并确定要渲染的组件。匹配是基于哈希值中 `#/` 后面的部分。 3. 组件渲染:根据匹配到的路由规则,HashRouter 会将对应的组件渲染到页面上。这些组件可以通过 Route 组件来定义和配置。 4. 哈希变化监听:HashRouter 会监听 URL 的哈希变化事件,当哈希值发生变化时,会重新进行路由匹配和组件渲染。 5. 导航操作:HashRouter 提供了一些导航方法,如 push、replace 和 go 等,可以通过编程方式进行导航操作。这些方法会修改 URL 的哈希部分,并触发相应的哈希变化事件。 总的来说,HashRouter原理是通过监听 URL 的哈希变化来确定当前的路由状态,并根据配置的路由规则将对应的组件渲染到页面上。使用 HashRouter 可以在不借助服务器的情况下实现页面之间的切换和导航。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

岚舟渡

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值