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 表单输入框不支持focus及blur事件的解决方案
Nov 17 Vue.js
vue-drawer-layout实现手势滑出菜单栏
Nov 19 Vue.js
vue中defineProperty和Proxy的区别详解
Nov 30 Vue.js
如何在vue 中使用柱状图 并自修改配置
Jan 21 Vue.js
vue监听键盘事件的相关总结
Jan 29 Vue.js
手动实现vue2.0的双向数据绑定原理详解
Feb 06 Vue.js
vue前端和Django后端如何查询一定时间段内的数据
Feb 28 Vue.js
vue打开新窗口并实现传参的图文实例
Mar 04 Vue.js
vue-router中hash模式与history模式的区别
Jun 23 Vue.js
Axios代理配置及封装响应拦截处理方式
Apr 07 Vue.js
vue本地构建热更新卡顿的问题“75 advanced module optimization”完美解决方案
Aug 05 Vue.js
vue实现简易音乐播放器
Aug 14 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
php实现四舍五入的方法小结
2015/03/03 PHP
location.search在客户端获取Url参数的方法
2010/06/08 Javascript
WEB高性能开发之疯狂的HTML压缩
2010/06/19 Javascript
js对数字的格式化使用说明
2011/01/12 Javascript
javascript中方便增删改cookie的一个类
2012/10/11 Javascript
js遍历td tr等html元素
2012/12/13 Javascript
FF火狐下获取一个元素同类型的相邻元素实现代码
2012/12/15 Javascript
js实现广告漂浮效果的小例子
2013/07/02 Javascript
jquery实现网页查找功能示例分享
2014/02/12 Javascript
Bootstrap框架结合jQuery仿百度换肤功能实例解析
2016/09/17 Javascript
Nodejs进阶:核心模块net入门学习与实例讲解
2016/11/21 NodeJs
JS限制条件补全问题实例分析
2016/12/16 Javascript
利用Node.js对文件进行重命名
2017/03/12 Javascript
结合Vue控制字符和字节的显示个数的示例
2018/05/17 Javascript
js中Object.defineProperty()方法的不详解
2018/07/09 Javascript
获取layer.open弹出层的返回值方法
2018/08/20 Javascript
JavaScript交换变量的常用方法小结【4种方法】
2020/05/07 Javascript
Tensorflow使用tfrecord输入数据格式
2018/06/19 Python
Python远程视频监控程序的实例代码
2019/05/05 Python
Django REST Framework之频率限制的使用
2019/09/29 Python
wxpython绘制音频效果
2019/11/18 Python
Pytorch 计算误判率,计算准确率,计算召回率的例子
2020/01/18 Python
基于jupyter代码无法在pycharm中运行的解决方法
2020/04/21 Python
Python新手学习装饰器
2020/06/04 Python
HTML5学习笔记之History API
2015/02/26 HTML / CSS
中国旅游网站:同程旅游
2016/09/11 全球购物
"序列点" 是什么
2016/07/29 面试题
个人实用的自我评价范文
2013/11/23 职场文书
旅游管理毕业生自荐书
2014/02/02 职场文书
培训楼经理岗位责任制
2014/02/10 职场文书
一年级班主任感言
2014/03/08 职场文书
百货商场楼层班组长竞聘书
2014/03/31 职场文书
学生吸烟检讨书
2014/09/14 职场文书
运动会跳远广播稿
2015/08/19 职场文书
PHP中->和=>的意思
2021/03/31 PHP
Android自定义ScrollView实现阻尼回弹
2022/04/01 Java/Android