vue-router中hash模式与history模式的区别


Posted in Vue.js onJune 23, 2021

vue-router有两种模式

  • hash模式
  • history模式

1.单页面应用

单页应用

1.只有一个html文件,整个网站的所有内容都在这一个html里,通过js来处理

2.不仅仅是在页面交互是无刷新的,连页面跳转都是无刷新的。为了实现单页应用 ==> 前后端分离 + 前端路由。(更新视图但不重新请求页面)

前端路由

实现起来其实也很简单,就是匹配不同的 url 路径,进行解析,加载不同的组件,然后动态的渲染出区域 html 内容。

优点

良好的交互体验,用户不需要刷新页面,页面显示流畅, 良好的前后端工作分离模式,减轻服务器压力,

缺点

不利于SEO,初次加载耗时比较多

2.hash模式

原理:是onhashchange事件,可以在window对象上监听这个事件

vue-router默认的是hash模式

1.使用URL的hash来模拟一个完整的URL

2.当URL改变的时候,页面不会重新加载,也就是单页应用了

2.当#后面的hash发生变化,不会导致浏览器向服务器发出请求,浏览器不发出请求就不会刷新页面,并且会触发hasChange这个事件,通过监听hash值的变化来实现更新页面部分内容的操作

window.onhashchange = function(event){
    console.log(event.oldURL, event.newURL);
    let hash = location.hash.slice(1);
    document.body.style.color = hash;
}

对于hash模式会创建hashHistory对象,在访问不同的路由的时候,会发生两件事:

1.HashHistory.push()将新的路由添加到浏览器访问的历史的栈顶,

2.HasHistory.replace()替换到当前栈顶的路由

vue-router中hash模式与history模式的区别

3.history模式

随着history api的到来,前端路由开始进化了,前面的hashchange,你只能改变#后面的url片段,而history api则给了前端完全的自由

  • history api可以分为两大部分:切换和修改

3.1 切换历史状态

包括back,forward,go三个方法
对应浏览器的前进,后退,跳转操作
例如:(谷歌)浏览器只有前进和后退,没有跳转,嗯,在前进后退上长按鼠标,会出来所有当前窗口的历史记录,从而可以跳转(也许叫跳更合适):

history.go(-2);//后退两次
history.go(2);//前进两次
history.back(); //后退
hsitory.forward(); //前进

3.2 修改历史状态

包括了pushState,replaceState两个方法

这两个方法接收三个参数:stateObj,title,url

history.pushState({color:'red'}, 'red', 'red'})

window.onpopstate = function(event){
    console.log(event.state)
    if(event.state && event.state.color === 'red'){
        document.body.style.color = 'red';
    }
}

history.back();

history.forward();

步骤

1.通过pushstate把页面的状态保存在state对象中

2.当页面的url再变回这个url时,可以通过event.state取到这个state对象

3.从而可以对页面状态进行还原

4.这里的页面状态就是页面字体颜色,其实滚动条的位置,阅读进度,组件的开关的这些页面状态都可以存储到state的里面。

3.3 history模式怕啥

hash 和 history 的区别

history 模式

1.通过history api,我们丢掉了丑陋的#,但是它也有个毛病

2.不怕前进,不怕后退,就怕刷新,f5

——history模式会将URL修改得就和正常请求后端的URL一样,如后端没有配置对应/user/id的路由处理,则会返回404错误

——所以这个实现需要服务器的支持,需要把所有路由都重定向到根页面。

ash模式下

1.前面的hashchange,你只能改变#后面的url片段。而pushState设置的新URL可以是与当前URL同源的任意URL。

2.前端路由修改的是#中的信息,而浏览器请求时是不带它玩的,所以没有问题.但是在history下,你可以自由的修改path,当刷新时,如果服务器中没有相应的响应或者资源,会分分钟刷出一个404来。

总结

到此这篇关于vue-router中hash模式与history模式区别的文章就介绍到这了,更多相关vue-router模式区别内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Vue.js 相关文章推荐
vue+vant实现购物车全选和反选功能
Nov 17 Vue.js
Vue项目利用axios请求接口下载excel
Nov 17 Vue.js
vue 使用 sortable 实现 el-table 拖拽排序功能
Dec 26 Vue.js
详解vue之自行实现派发与广播(dispatch与broadcast)
Jan 19 Vue.js
vue-cli中实现响应式布局的方法
Mar 02 Vue.js
Vue中避免滥用this去读取data中数据
Mar 02 Vue.js
详解Vue的sync修饰符
May 15 Vue.js
vue点击弹窗自动触发点击事件的解决办法(模拟场景)
May 25 Vue.js
Vue过滤器(filter)实现及应用场景详解
Jun 15 Vue.js
Vue2.0搭建脚手架
Mar 13 Vue.js
VUE解决跨域问题Access to XMLHttpRequest at
May 06 Vue.js
vue实现登陆页面开发实践
May 30 Vue.js
Vue-Element-Admin集成自己的接口实现登录跳转
Vue + iView实现Excel上传功能的完整代码
Vue vee-validate插件的简单使用
Jun 22 #Vue.js
vue3使用vue-router的完整步骤记录
一篇文章学会Vue中间件管道
Jun 20 #Vue.js
Vue过滤器(filter)实现及应用场景详解
使用Vue3+Vant组件实现App搜索历史记录功能(示例代码)
You might like
UCenter 批量添加用户的php代码
2012/07/17 PHP
解析php中memcache的应用
2013/06/18 PHP
PHP缓存集成库phpFastCache用法
2014/12/15 PHP
XP折叠菜单&仿QQ2006菜单
2006/12/16 Javascript
取键盘键位ASCII码的网页
2007/07/30 Javascript
根据出生日期自动取得星座的js代码
2010/07/20 Javascript
jQuery获取样式中颜色值的方法
2015/01/29 Javascript
JS使用eval解析JSON的注意事项分析
2015/11/14 Javascript
jQuery中的each()详细介绍(推荐)
2016/05/25 Javascript
理解JavaScript原型链
2016/10/25 Javascript
详解Vue 方法与事件处理器
2017/06/20 Javascript
详解VueRouter进阶之导航钩子和路由元信息
2017/09/13 Javascript
JS中图片压缩的方法小结
2017/11/14 Javascript
jQuery实现表格隔行换色
2018/09/01 jQuery
Vue 监听列表item渲染事件方法
2018/09/06 Javascript
Node.js从字符串生成文件流的实现方法
2019/08/18 Javascript
微信小程序自定义波浪组件使用方法详解
2019/09/21 Javascript
JavaScript中的this原理及6种常见使用场景详解
2020/02/14 Javascript
React.js组件实现拖拽排序组件功能过程解析
2020/04/27 Javascript
js实现3D粒子酷炫动态旋转特效
2020/09/13 Javascript
[06:14]《辉夜杯》外卡赛附加赛 4支战队巡礼
2015/10/23 DOTA
python使用matplotlib库生成随机漫步图
2018/08/27 Python
python使用ddt过程中遇到的问题及解决方案【推荐】
2018/10/29 Python
Django缓存系统实现过程解析
2019/08/02 Python
pytest fixtures装饰器的使用和如何控制用例的执行顺序
2021/01/28 Python
size?法国官网:英国伦敦的球鞋精品店
2020/03/15 全球购物
俄罗斯品牌服装在线商店:VIPAVENUE
2020/08/10 全球购物
采购内勤岗位职责
2013/12/10 职场文书
医务工作者先进事迹材料
2014/01/26 职场文书
简历的自我评价范文
2014/02/04 职场文书
小小商店教学反思
2014/04/27 职场文书
奉献演讲稿范文
2014/05/21 职场文书
机电一体化专业毕业生自荐信
2014/06/19 职场文书
励志演讲稿600字
2014/08/21 职场文书
关于保护环境的建议书
2014/08/26 职场文书
巾帼标兵事迹材料
2014/12/26 职场文书