Vue-Router入门(六) :路由的不同模式

前言

Vue Router 提供了多种路由模式,每种模式都有其特点和适用场景。在本文中,我们将详细介绍 Vue 路由的几种模式及其区别。

Hash 模式

hash 模式是用 createWebHashHistory() 创建的。

js 复制代码
import { createRouter, createWebHashHistory } from 'vue-router'

const router = createRouter({
  history: createWebHashHistory(),
  routes: [
    //...
  ],
})

原理

利用 window.onhashchange 事件监听 hash 值的变化这个事件会在 URL 的 Hash 部分发生变化时触发 通过监听 hashchange 事件,可以捕获到URLHash部分的变化。一旦hash值发生变化,就可以触发相应的回调函数,实现页面的跳转和渲染。

特点

  1. 在 Hash 模式下,URL 中始终包含一个以"#"为前缀的部分。例如:http://example.com/#/home

  2. 与传统的服务端路由不同。Hash不会被包括在HTTP请求中。换句话说,在进行路由切换时,不会向服务器发送额外的请求。这使得前端能够完全掌控路由的变化。

  3. 在 Hash 模式下,页面的切换不会导致完整页面的重新加载。

注意: Hash 模式在传递的实际URL之前使用了一个哈希字符不过有些搜索引擎可能不会正确索引带有 # 符号的 URL。所以它在 SEO 中确实有不好的影响

History 模式

History 模式是用 createWebHistory()创建的。

js 复制代码
import { createRouter, createWebHistory } from 'vue-router'

const router = createRouter({
  history: createWebHistory(),
  routes: [
    //...
  ],
})

原理

History 模式使用 history.pushState()replaceState() 这两个 API 来操作 URL。这两个方法可以改变当前浏览器的地址栏 URL,而不会触发页面的重新加载。通过监听 popstate 事件来捕获 URL 的变化,这个事件会在浏览器的历史记录发生变化时触发。

特点

  • History 模式下的 URL 更加规范 :不再包含以"#"为前缀的部分,例如:http://example.com/home。相比Hash模式,这使得URL更具可读性和美观性。

  • History 模式需要服务器配置支持 :在使用 History 模式时,确保服务器配置正确,以便在直接访问页面时能够正确路由到对应的页面。如果服务器没有配置相应的页面,用户访问时,就会得到一个404错误。

区别

  1. URL 形式 :Hash 模式和 History 模式在 URL 表现上有明显差异。Hash 模式使用 # 符号,而 History 模式不使用。History 模式的 URL 更美观、清晰。
  2. 兼容性:Hash 模式兼容性更好,而 History 模式需要服务器端配置支持。
  3. 用户体验:History 模式在用户体验上更优,因为它可以实现无刷新页面加载,不会出现页面跳转时的闪烁。
  4. SEO:History 模式对搜索引擎更友好,因为 URL 更规范、清晰。
  5. 部署:Hash 模式相对更简单,不需要额外的服务器配置,而 History 模式在部署时需要特殊配置以确保路由的正常运行。
相关推荐
donecoding1 小时前
一个 sudo 引发的血案:npm 全局包权限错乱彻底修复
前端·node.js·前端工程化
风骏时光牛马1 小时前
Raku正则匹配与数据批量处理实操案例
前端
nbwenren1 小时前
2026实测:Gemini 3 镜像站视觉能力实践——拍照原型图,一键生成 HTML+CSS 代码
前端·css·html
Lee川1 小时前
Prisma 实战指南:像搭积木一样设计古诗词数据库
前端·数据库·后端
jinanwuhuaguo1 小时前
(第二十九篇)OpenClaw 实时与具身的跃迁——从异步孤岛到数字世界的“原住民”
前端·网络·人工智能·重构·openclaw
广州华水科技2 小时前
深度测评2026年单北斗GNSS位移监测系统推荐,与高口碑变形监测设备一同引领行业新风尚
前端
Alice-YUE2 小时前
【js高频八股】防抖与节流
开发语言·前端·javascript·笔记·学习·ecmascript
是上好佳佳佳呀4 小时前
【前端(十一)】JavaScript 语法基础笔记(多语言对比)
前端·javascript·笔记
CDN3604 小时前
排查实录:网站偶发502/504错误?360CDN回源超时配置与日志分析技巧
前端·数据库