Vue Router——hash模式和 history模式

在 Vue.js 中,Vue Router 是官方提供的路由管理器,它允许你以单页面应用(SPA)的方式构建你的Vue应用。Vue

Router 支持两种路由模式:hash 模式和 history

模式。这两种模式的主要区别在于它们如何与浏览器的历史记录(History API)交互以及 URL 的形式。

Hash 模式

Hash 模式是 Vue Router 的默认模式。它使用 URL 的 hash(即 URL 中 # 后面的部分)来模拟一个完整的 URL,从而实现页面的跳转而无需重新加载页面。在 Hash 模式下,当 URL 改变时,页面不会重新加载。

Hash 模式的示例 URL:http://www.example.com/#/about

优点:

  • 兼容性好,可以在不支持 History API 的旧浏览器中使用。
  • 由于是基于锚点变化,不会向服务器发送请求获取新页面。

缺点:

  • URL 中会包含 #,对于某些需要 URL 干净的场景(如SEO)可能不是最佳选择。

History 模式

History 模式利用了 HTML5 的 History API 来实现页面的跳转而无需重新加载。这种模式允许你创建没有 hash 的正常 URL。

History 模式的示例 URL:http://www.example.com/about

优点:

  • URL 不含有 #,更加美观,对于需要 URL 干净的场景(如SEO)更加友好。

缺点:

  • 需要服务器端支持。因为在 History 模式下,如果用户直接访问或刷新非首页的 URL,服务器会收到一个路径请求,如果服务器没有被正确配置来匹配这个路径,就会返回 404 错误。因此,需要在服务器端添加一个回退处理,以便对所有的路径请求返回同一个 HTML 文件。
  • 不支持不支持 History API 的旧浏览器。

总结

选择哪种模式主要取决于你的需求以及目标浏览器的兼容性。如果你需要一个看起来更像传统网页的 URL 或者是在做SEO优化,History 模式可能是更好的选择,只要确保你的服务器配置能正确处理 SPA 的路由请求。如果你更关注兼容性或者不想额外配置服务器,那么 Hash 模式可能是更方便的选项。

相关推荐
wearegogog1237 小时前
基于 MATLAB 的卡尔曼滤波器实现,用于消除噪声并估算信号
前端·算法·matlab
Drawing stars7 小时前
JAVA后端 前端 大模型应用 学习路线
java·前端·学习
品克缤7 小时前
Element UI MessageBox 增加第三个按钮(DOM Hack 方案)
前端·javascript·vue.js
小二·7 小时前
Python Web 开发进阶实战:性能压测与调优 —— Locust + Prometheus + Grafana 构建高并发可观测系统
前端·python·prometheus
小沐°7 小时前
vue-设置不同环境的打包和运行
前端·javascript·vue.js
Irene19918 小时前
Vue3 <Suspense> 使用指南与注意事项
vue.js·suspense
qq_419854058 小时前
CSS动效
前端·javascript·css
烛阴8 小时前
3D字体TextGeometry
前端·webgl·three.js
桜吹雪8 小时前
markstream-vue实战踩坑笔记
前端
C_心欲无痕9 小时前
nginx - 实现域名跳转的几种方式
运维·前端·nginx