路由Hash与History

本文介绍了Vue Router中的两种路由模式:Hash和History。Hash模式的URL带有#号,适合开发,但在某些第三方应用中可能受限;而History模式提供无#号的正常URL,适合推广,但可能导致404错误。在History模式下,URL改变不会发送HTTP请求,刷新时需后端配合防止404。实现原理上,History模式依赖pushState和replaceState方法,Hash模式则利用onhashchange事件。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1.url不同

Hash :Hash模式url里面永远带着#号,我们在开发当中默认使用这个模式。

History:如果用户考虑url的规范那么就需要使用History模式,因为history模式没有#号,是个正常的url适合推广宣传。当然其功能也有区别,比如我们在开发app的时候有分享页面,那么这个分享出去的页面就是用vue或是react做的,把这个页面分享到第三方的app里,有的app里面url是不允许带有#号的,所以要将#号去除那么就要使用history模式。

2.http请求

Hash :仅 # 之前的内容包含在 http 请求中,后面部分虽然出现在 URL 中,但不会被包括在 HTTP 请求中,对后端完全没有影响,因此改变 hash 不会重新加载页面。

History:将url替换并且不刷新页面,http并没有去请求服务器该路径下的资源

3.History出现404

history 在刷新页面时,如果服务器中没有相应的响应或资源,就会出现404。(比如在访问二级页面的时候,做刷新操作)

hash 模式下,仅 # 之前的内容包含在 http 请求中,对后端来说,即使没有对路由做到全面覆盖,也不会报 404。

解决方案:如果 URL 匹配不到任何静态资源,则应该返回同一个 index.html 页面,这个页面就是你 app 依赖的页面。(后端人员配置一下apache或是nginx的url重定向,重定向到前端首页路由上)。开发时用hash模式,build时用history。

4.实现原理

History:利用了 html5 history interface 中新增的 pushState() 和 replaceState() 方法。
Hash:原理是 onhashchange 事件,可以在 window 对象上监听这个事件。

/*历史模式*/
<a class="api a">a.html</a>
<a class="api b">b.html</a>
  <script type="text/javascript">
    //注册路由
    document.querySelectorAll('.api').forEach(item => {
      item.addEventListener('click', e => {
        //阻止默认事件
        e.preventDefault();
        //当前链接
        let link = item.textContent;
        //创建一个历史记录,注册一个路由
        window.history.pushState({ name: 'api' }, link, link);
      }, false);
    });
    //监听路由,前进后退的时候触发
    window.addEventListener('popstate', e => {
      console.log({
        location: location.href,
        state: e.state
      });
    }, false)
  </script>
  
/*哈希模式*/
  <a class="hash a">#a.html</a>
  <a class="hash b">#b.html</a>
  <script type="text/javascript">
    //注册路由
    document.querySelectorAll('.hash').forEach(item => {
      item.addEventListener('click', e => {
        //阻止默认事件
        e.preventDefault();
        //当前链接
        let link = item.textContent;
        location.hash = link;
      }, false);
    });

    //监听路由,用hashchange事件
    window.addEventListener('hashchange', e => {
      console.log({
        location: location.href,
        hash: location.hash
      });
    }, false)
  </script>

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值