梳理下hash/history两种路由模式的区别。
后端路由:在前后端不分离的时代,路由都是通过服务端指定的,服务端根据客户端发来的HTTP请求,将返回的数据于模板引擎响应结果结合后进行渲染,将渲染完毕的页面发送给客户端。
优点:SEO友好,爬虫爬取到的页面就是最终的渲染结果。
缺点:每次发起请求都要刷新页面,用户体验不好,服务器压力大。
SPA是单页面应用Single Page web Application的简写。简单理解就是一个web项目只有一个html文件,一旦页面加载完成,SPA不会因为用户的操作进行重新加载或跳转,而是用JS动态变换html的内容(使页面无需重新加载,用户体验更加流程),页面本身的url并没有变化,这将导致两个问题:
1.SPA无法就记住用户的操作:刷新 & 前进 & 后退。
2.实际只有一个url,对SEO不友好,爬虫获取到的html只是模板而不是最终的页面。
www.baidu.com/#hashhash
由以上特点可见,hash模式完全满足前端路由的需求,因此在h5的history模式出现之前,基本都是使用hash模式实现前端路由。
history.go(n) // n>0前进n页;n<0后退n页
history.forward() // 前进一页
history.back() // 后退一页
/*
参数说明:
state:合法的JavaScript对象,可以用在popstate对象中
title:标题,基本忽略,用null
url: 任意有效的url,将要跳转的新地址
*/
history.pushState(state, title, url) // 保留现有记录的同时,将url加到历史记录中
history.replaceState(state, title, url) // 将历史记录中的当前页面替换成url
history.state // 返回当前状态对象
pushState
和replaceState
方法可以改变url,但是不会刷新页面,浏览器不会向服务端发送请求,具备了实现前端路由的能力。hashchange
方法,history的变化不会触发任何事件,我们可以通过罗列可能触发history变化的情况,对这些情况进行拦截,以此监听history的变化。history.pushState()
或history.replaceState()
onhashchange()
事件,查找对应的路由规则;history利用H5新增的pushState()
和replaceState()
方法改变url。pushState()
设置的url于当前url一模一样也会被记录到历史记录栈。一般情况下,vue-router前端路由使用hash和history模式都可以。
pushState()
设置的url可以是与当前url同源的url;而hash只能改变#后面的内容,只能设置于当前url同文档的url。pushState()
设置的url与当前url一模一样也会被添加到历史记录栈;hash必须#后面的内容被更新才会记录。pushState()
可以通过stateObject参数添加任意类型的数据到记录中,而hash只能添加短字符串。参考链接:
https://zhuanlan.zhihu.com/p/364019280https://www.cnblogs.com/zhif97/p/13875513.html
https://juejin.cn/post/6844903890278694919#heading-7
https://www.jianshu.com/p/0b65723c18bd