vue router 的两种路由模式hash与history的区别
文章目录
- 两种模式
- 特点
- 总结
两种模式
前端路由的核心,就在于 —— 改变视图的同时不会向后端发出请求。
hash
模式是通过改变锚点(#)来更新页面URL,并不会触发页面重新加载,我们可以通过window.onhashchange
监听到hash
的改变,从而处理路由。history
模式是通过调用window.history
对象上的一系列方法来实现页面的无刷新跳转。
特点
hash
hash,原本用来结合锚点控制页面视窗的位置,具有以下特点:
- 可以改变URL,但不会触发页面重新加载(
hash
的改变会记录在window.hisotry
中)因此并不算是一次http
请求,所以这种模式不利于SEO
优化 - 只能修改
#
后面的部分,因此只能跳转与当前URL同文档的URL - 只能通过字符串改变URL
- 通过
window.onhashchange
监听hash
的改变,借此实现无刷新跳转的功能。
history
根据 Mozilla Develop Network 的介绍,调用 history.pushState()
相比于直接修改 hash
,存在以下优势
- 新的URL可以是与当前URL同源的任意 URL,也可以与当前URL一样,但是这样会把重复的一次操作记录到栈中
- 通过参数
stateObject
可以添加任意类型的数据到记录中 - 可额外设置
title
属性供后续使用 - 通过
pushState
、replaceState
实现无刷新跳转的功能。
存在问题
当应用通过vue-router
跳转到某个页面后,因为此时是前端路由控制页面跳转,虽然url改变,但是页面只是内容改变,并没有重新请求,所以这套流程没有任何问题。但是,如果在当前的页面刷新一下,此时会重新发起请求,如果nginx
没有匹配到当前url,就会出现404
的页面。那为什么hash模式不会出现这个问题呢?因为hash
虽然可以改变URL,但不会被包括在HTTP
请求中。它被用来指导浏览器动作,并不影响服务器端,因此,改变hash
并没有改变url,所以页面路径还是之前的路径,nginx
不会拦截。
因此,切记在使用history
模式时,需要服务端允许地址可访问,否则就会出现404
的尴尬场景。
总结
- 在
hash
模式下,所有的页面跳转都是客户端进行操作,因此对于页面拦截更加灵活;但每次url的改变不属于一次http请求,所以不利于SEO
优化。 - 在
history
模式下,借助history.pushState
实现页面的无刷新跳转;这种方式URL
的改变属于http请求,因此会重新请求服务器,这也使得我们必须在服务端配置好地址,否则服务端会返回404
,为确保不出问题,最好在项目中配置404页面。
vue router 的两种路由模式hash与history的区别相关推荐
- Vue-Router的两种路由模式
对于 Vue 这类渐进式前端开发框架,为了构建 SPA(单页面应用),需要引入前端路由系统,这也就是 Vue-Router 存在的意义.前端路由的核心,就在于 -- 改变视图的同时不会向后端发出请求. ...
- vue的两种路由模式原理
参考:https://juejin.cn/post/7127143415879303204 react中路由模式分为hash路由和history路由.hash路由的原理是window.onhashch ...
- vue 的两种路由模式
第一种 hash 模式 后面带#号 http://xx.xxx.x.xxx:8080/#/index 切换路由,只改变#后面的值,就可以切换路由,不重新刷新页面,浏览器也会记录,左右箭头可以进行前进和 ...
- vue路由的两种模式:hash与history的区别
前言:众所周知,vue-router有两种模式,hash模式和history模式,下面来看看两者的区别. 一.基本情况 直观区别:hash模式url带#号,history模式不带#号. 1.hash模 ...
- Vue router 模式 hash 和 history
目录 Vue router 基本使用 Vue-router 传参 hash 模式 Vue-router hash history 模式 Vue router 基本使用 用 Vue + Vue Rout ...
- [html] history和hash两种路由方式的最大区别是什么?
[html] history和hash两种路由方式的最大区别是什么? hash 只在当前URL内刷新,history支持多个URL 个人简介 我是歌谣,欢迎和大家一起交流前后端知识.放弃很容易, 但坚 ...
- drf-路由组件:自动生成Routers路由、 使用方法、视图集中附加action的声明、自动生成路由router的两种方式的URL区别
目录 一. 自动生成Routers路由 二. 使用方法 1) 创建router对象,并注册视图集,例如 2)添加路由数据 三. 代码演示 四. 视图集中附加action的声明 五. 自动生成路由rou ...
- 微前端:qiankun的两种运作模式
背景 微前端 qiankun 有两种运作模式: 1.使用 registerMicroApps + start,这是挂自动档,路由改变,重新load子应用. 2.使用 loadMicroApp,每次路由 ...
- 8086的两种工作模式_Buck变换器工作原理
一.Buck变换器另外三种叫法 1.降压变换器:输出电压小于输入电压. 2.串联开关稳压电源:单刀双掷开关(晶体管)串联于输入与输出之间. 3.三端开关型降压稳压电源: 1)输入与输出的一根线是公用的 ...
最新文章
- java 圆桌_约瑟夫问题求解释(圆桌问题)Java
- 【数据结构】二叉树的存储和遍历
- 服务器遍历文件夹不按顺序,绕过遍历检查 (Windows 10) - Windows security | Microsoft Docs...
- 今天发现新大陆:haml和Emmet
- UML基础: 统一建模语言简介
- python杂志订阅系统详细设计_图书管理系统详细设计说明书(完整).doc
- python调用有道翻译_Python通过调用有道翻译api实现翻译功能示例
- 分式加法JAVA程序_分式加减运算的八种技巧,有几种方法学校老师没讲过,记得收藏...
- 基于安卓的高清语音技术亮相中国国际通信展览会
- 写500字关于漫威英雄的论文
- 遇到这样的一个求职者,真心无力吐槽了
- Android简易计分器
- HR管理的本质是激发每一个人的善意
- 100多个flash常见问题大收集
- 笔记本一开机就跳出来计算机,电脑开机就自动进入BIOS界面,该怎么解决?
- 在c语言中sqr怎么变成int,Basi与c语言基础.ppt
- html入门介绍,html标签入门介绍
- 探讨Docker不能启动容器的原因和解决方法
- SEO优化之147SEO搜索引擎推送工具
- matlab神经网络建模程序,人工神经网络建模matlab..ppt