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使用Element实现增删改查+打包的步骤
Nov 25 Vue.js
ESLint 是如何检查 .vue 文件的
Nov 30 Vue.js
详解Vue3 Teleport 的实践及原理
Dec 02 Vue.js
vue+element_ui上传文件,并传递额外参数操作
Dec 05 Vue.js
在vue中动态修改css其中一个属性值操作
Dec 07 Vue.js
Vue组件简易模拟实现购物车
Dec 21 Vue.js
Vue 实现可视化拖拽页面编辑器
Feb 01 Vue.js
vue引入Excel表格插件的方法
Apr 28 Vue.js
Vue详细的入门笔记
May 10 Vue.js
Vue3中的Refs和Ref详情
Nov 11 Vue.js
Vue组件化(ref,props, mixin,.插件)详解
May 15 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
curl 出现错误的调试方法(必看)
2017/02/13 PHP
csdn 博客的css样式 v3
2009/02/24 Javascript
JavaScript 入门基础知识 想学习js的朋友可以参考下
2009/12/26 Javascript
js中substring和substr的详细介绍与用法
2013/08/29 Javascript
用javascript添加控件自定义属性解析
2013/11/25 Javascript
Javascript中获取对象的原型对象的方法小结
2015/02/25 Javascript
jquery实现表单输入时提示文字滑动向上效果
2015/08/10 Javascript
jquery控制页面的展开和隐藏实现方法(推荐)
2016/10/15 Javascript
关于Node.js中Buffer的一些你可能不知道的用法
2017/03/28 Javascript
利用JS测试目标网站的打开响应速度
2017/12/01 Javascript
10个在JavaScript开发中常遇到的BUG
2017/12/18 Javascript
Vue Router的懒加载路径的解决方法
2018/06/21 Javascript
JS如何实现封装列表右滑动删除收藏按钮
2020/07/23 Javascript
9个JavaScript日常开发小技巧
2020/10/06 Javascript
Python执行时间的计算方法小结
2017/03/17 Python
django 在原有表格添加或删除字段的实例
2018/05/27 Python
对python中array.sum(axis=?)的用法介绍
2018/06/28 Python
TensorFlow实现模型评估
2018/09/07 Python
python3实现猜数字游戏
2020/12/07 Python
python SQLAlchemy的Mapping与Declarative详解
2019/07/04 Python
python__name__原理及用法详解
2019/11/02 Python
python 解决函数返回return的问题
2020/12/05 Python
全方位了解CSS3的Regions扩展
2015/08/07 HTML / CSS
linux面试题参考答案(4)
2014/09/21 面试题
毕业生文员求职信
2013/11/03 职场文书
求职自荐信格式
2013/12/04 职场文书
护士优质服务演讲稿
2014/08/26 职场文书
房屋出租协议书范本(标准版)
2014/09/24 职场文书
2014年圣诞节寄语
2014/12/08 职场文书
教师学习心得体会范文
2016/01/21 职场文书
机械生产实习心得体会
2016/01/22 职场文书
音乐课《小猫钓鱼》教学反思
2016/02/18 职场文书
2019数学教师下学期工作总结
2019/06/27 职场文书
一劳永逸彻底解决pip install慢的办法
2021/05/24 Python
使用python创建股票的时间序列可视化分析
2022/03/03 Python
SQL Server #{}可以防止SQL注入
2022/05/11 SQL Server