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中通过render函数给子组件设置ref操作
Nov 17 Vue.js
详解vue 组件注册
Nov 20 Vue.js
Vue.js桌面端自定义滚动条组件之美化滚动条VScroll
Dec 01 Vue.js
vue使用exif获取图片旋转,压缩的示例代码
Dec 11 Vue.js
vue实现两个区域滚动条同步滚动
Dec 13 Vue.js
vue 导航守卫和axios拦截器有哪些区别
Dec 19 Vue.js
Vue.extend 登录注册模态框的实现
Dec 29 Vue.js
SpringBoot+Vue 前后端合并部署的配置方法
Dec 30 Vue.js
vue项目配置 webpack-obfuscator 进行代码加密混淆的实现
Feb 26 Vue.js
原生JS封装vue Tab切换效果
Apr 28 Vue.js
Vue实现导入Excel功能步骤详解
Jul 03 Vue.js
vue项目中的支付功能实现(微信支付和支付宝支付)
Feb 18 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实现jQuery扩展函数
2009/10/30 PHP
PHP缓存集成库phpFastCache用法
2014/12/15 PHP
PHP正则表达式之捕获组与非捕获组
2015/11/06 PHP
利用PHP内置SERVER开启web服务(本地开发使用)
2020/01/22 PHP
PhpStorm的使用教程(本地运行PHP+远程开发+快捷键)
2020/03/26 PHP
JS trim去空格的最佳实践
2011/10/30 Javascript
javascript中的toFixed固定小数位数 简单实例分享
2013/07/12 Javascript
解析Javascript小括号“()”的多义性
2013/12/03 Javascript
让浏览器DOM元素最后加载的js方法
2014/07/29 Javascript
让IE8浏览器支持function.bind()方法
2014/10/16 Javascript
JS 实现列表与多选框选择附预览动画
2014/10/29 Javascript
jQuery超赞的评分插件(8款)
2015/08/20 Javascript
AngularJS ng-change 指令的详解及简单实例
2016/07/30 Javascript
AngularJS入门教程之双向绑定详解
2016/08/18 Javascript
Javascript中的prototype与继承
2017/02/06 Javascript
vue表单绑定实现多选框和下拉列表的实例
2017/08/12 Javascript
vue中实现左右联动的效果
2018/06/22 Javascript
python通过zlib实现压缩与解压字符串的方法
2014/11/19 Python
python放大图片和画方格实现算法
2018/03/30 Python
pandas使用apply多列生成一列数据的实例
2018/11/28 Python
Python批量修改图片分辨率的实例代码
2019/07/04 Python
pytorch打印网络结构的实例
2019/08/19 Python
python 内置函数汇总详解
2019/09/16 Python
pygame实现贪吃蛇游戏(下)
2019/10/29 Python
Python计算机视觉里的IOU计算实例
2020/01/17 Python
通过自学python能找到工作吗
2020/06/21 Python
python代码能做成软件吗
2020/07/24 Python
施华洛世奇美国官网:SWAROVSKI美国
2018/02/08 全球购物
美国睫毛、眉毛精华液领导品牌:RevitaLash Cosmetics
2018/03/26 全球购物
新加坡网上美容店:Hermo新加坡
2019/06/19 全球购物
幼儿园秋季开学寄语
2014/08/02 职场文书
收款委托书
2014/10/14 职场文书
超市工作总结范文2014
2014/12/19 职场文书
办公经费申请报告
2015/05/15 职场文书
加强党性修养心得体会
2016/01/21 职场文书
在Django中使用MQTT的方法
2021/05/10 Python