文章目录

  • 两种模式
  • 特点
  • 总结

两种模式

前端路由的核心,就在于 —— 改变视图的同时不会向后端发出请求。

  • 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属性供后续使用
  • 通过pushStatereplaceState实现无刷新跳转的功能。

存在问题
当应用通过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的区别相关推荐

  1. Vue-Router的两种路由模式

    对于 Vue 这类渐进式前端开发框架,为了构建 SPA(单页面应用),需要引入前端路由系统,这也就是 Vue-Router 存在的意义.前端路由的核心,就在于 -- 改变视图的同时不会向后端发出请求. ...

  2. vue的两种路由模式原理

    参考:https://juejin.cn/post/7127143415879303204 react中路由模式分为hash路由和history路由.hash路由的原理是window.onhashch ...

  3. vue 的两种路由模式

    第一种 hash 模式 后面带#号 http://xx.xxx.x.xxx:8080/#/index 切换路由,只改变#后面的值,就可以切换路由,不重新刷新页面,浏览器也会记录,左右箭头可以进行前进和 ...

  4. vue路由的两种模式:hash与history的区别

    前言:众所周知,vue-router有两种模式,hash模式和history模式,下面来看看两者的区别. 一.基本情况 直观区别:hash模式url带#号,history模式不带#号. 1.hash模 ...

  5. Vue router 模式 hash 和 history

    目录 Vue router 基本使用 Vue-router 传参 hash 模式 Vue-router hash history 模式 Vue router 基本使用 用 Vue + Vue Rout ...

  6. [html] history和hash两种路由方式的最大区别是什么?

    [html] history和hash两种路由方式的最大区别是什么? hash 只在当前URL内刷新,history支持多个URL 个人简介 我是歌谣,欢迎和大家一起交流前后端知识.放弃很容易, 但坚 ...

  7. drf-路由组件:自动生成Routers路由、 使用方法、视图集中附加action的声明、自动生成路由router的两种方式的URL区别

    目录 一. 自动生成Routers路由 二. 使用方法 1) 创建router对象,并注册视图集,例如 2)添加路由数据 三. 代码演示 四. 视图集中附加action的声明 五. 自动生成路由rou ...

  8. 微前端:qiankun的两种运作模式

    背景 微前端 qiankun 有两种运作模式: 1.使用 registerMicroApps + start,这是挂自动档,路由改变,重新load子应用. 2.使用 loadMicroApp,每次路由 ...

  9. 8086的两种工作模式_Buck变换器工作原理

    一.Buck变换器另外三种叫法 1.降压变换器:输出电压小于输入电压. 2.串联开关稳压电源:单刀双掷开关(晶体管)串联于输入与输出之间. 3.三端开关型降压稳压电源: 1)输入与输出的一根线是公用的 ...

最新文章

  1. java 圆桌_约瑟夫问题求解释(圆桌问题)Java
  2. 【数据结构】二叉树的存储和遍历
  3. 服务器遍历文件夹不按顺序,绕过遍历检查 (Windows 10) - Windows security | Microsoft Docs...
  4. 今天发现新大陆:haml和Emmet
  5. UML基础: 统一建模语言简介
  6. python杂志订阅系统详细设计_图书管理系统详细设计说明书(完整).doc
  7. python调用有道翻译_Python通过调用有道翻译api实现翻译功能示例
  8. 分式加法JAVA程序_分式加减运算的八种技巧,有几种方法学校老师没讲过,记得收藏...
  9. 基于安卓的高清语音技术亮相中国国际通信展览会
  10. 写500字关于漫威英雄的论文
  11. 遇到这样的一个求职者,真心无力吐槽了
  12. Android简易计分器
  13. HR管理的本质是激发每一个人的善意
  14. 100多个flash常见问题大收集
  15. 笔记本一开机就跳出来计算机,电脑开机就自动进入BIOS界面,该怎么解决?
  16. 在c语言中sqr怎么变成int,Basi与c语言基础.ppt
  17. html入门介绍,html标签入门介绍
  18. 探讨Docker不能启动容器的原因和解决方法
  19. SEO优化之147SEO搜索引擎推送工具
  20. matlab神经网络建模程序,人工神经网络建模matlab..ppt

热门文章

  1. Angle Admin Template介绍
  2. 编程之美-快速费波拉契数列
  3. C++测试题练习题1
  4. Java对象转出json并过滤指定属性
  5. XSL样式,分页方法
  6. 一個便宜的高负载网站架构
  7. weblogic部署,常见错误解决二——ClassCastException
  8. 阿里研究院:数据治理解决方案,附7篇数据治理完整版PDF下载
  9. XEIM_跨平台的网络通信产品
  10. 若你安全到家,来这儿报个平安吧