hash路由和history路由

一、基本概念

1. Hash 模式

原理

  • 通过 URL 中的 #(哈希值)来模拟路由,比如 http://example.com/#/home
  • 浏览器原生支持 hashchange 事件,当 # 后的内容变化时,页面不会刷新,但会触发路由切换。

特点

  • 兼容性好:支持所有浏览器(包括 IE8)。
  • 服务端无压力 :因为 # 后的内容不会发送到服务器,完全由前端处理。

示例

javascript 复制代码
// 监听路由变化
window.addEventListener('hashchange', () => {
  console.log('当前哈希:', location.hash); // 输出 "#/home"
});

2. History 模式

原理

  • 基于 HTML5 的 History APIpushStatereplaceState),直接操作浏览器历史栈,URL 更简洁(如 http://example.com/home)。
  • 需要服务端配合:因为路径是真实的,刷新页面时会向服务器请求该路径,需配置兜底返回 index.html

特点

  • URL 美观 :没有 #,更符合传统 URL 习惯。
  • 需服务端支持:否则刷新页面会 404。

示例

less 复制代码
// 添加新路由记录
history.pushState({}, '', '/home'); // URL 变为 /home,无刷新

对比总结

对比点 Hash 模式 History 模式
URL 美观性 #,不美观 #,更简洁
兼容性 所有浏览器 需要 IE10+
服务端要求 无需配置 需配置兜底路由

选择建议

  • 如果需要兼容旧浏览器或快速搭建,用 hash
  • 如果追求美观且能控制服务端配置,用 history

二、刷新页面情况

1. Hash 模式

  • 不会刷新页面的情况

    • 修改 # 后的哈希值(如 #/home#/about),触发 hashchange 事件。
    • 调用 router.push() 或手动修改 location.hash
  • 会刷新页面的情况

    • 直接修改 # 前的部分(如域名、路径、查询参数):

      ini 复制代码
      location.href = 'http://example.com/new-path#/home'; // 刷新页面
    • 手动刷新页面(F5 / 浏览器刷新按钮)

      页面会重新加载,但路由仍会匹配 # 后的内容(因为 # 后的部分不会发送到服务端)。


2. History 模式

  • 不会刷新页面的情况

    • 调用 history.pushState()history.replaceState() 修改 URL。
    • 前端路由库(如 Vue Router、React Router)的导航方法(如 router.push('/about'))。
  • 会刷新页面的情况

    • 手动刷新页面(F5 / 浏览器刷新按钮)

      浏览器会向服务器请求当前 URL(如 http://example.com/about),若服务端未配置兜底路由(返回 index.html),会返回 404。

    • 直接输入 URL 并回车

      等同于刷新页面,行为同上。

    • 修改非路由部分的 URL(如域名、协议、端口):

      ini 复制代码
      location.href = 'http://new-domain.com/about'; // 刷新并跳转

关键对比

操作 Hash 模式 History 模式
修改 # 后的部分 ❌ 不刷新 -
调用 pushState/push - ❌ 不刷新
手动刷新页面(F5) ⭕ 刷新 ⭕ 刷新(需服务端支持)
直接输入 URL 回车 ⭕ 刷新 ⭕ 刷新(需服务端支持)
修改 URL 非路由部分(如域名) ⭕ 刷新 ⭕ 刷新
相关推荐
默_笙2 分钟前
🛬 我让 AI 帮我写了一个打飞机游戏,结果 Canvas 把我整不会了
前端·javascript
梯度不陡2 分钟前
AI 到底能不能从零写软件?ProgramBench 和 RepoZero 给出了两种答案
前端·javascript·面试
冬奇Lab20 分钟前
每日一个开源项目(第137篇):Penpot - 真正开源的设计协作工具,SVG 原生格式消灭设计-开发鸿沟
前端·开源·设计
nuIl37 分钟前
实现一个 Coding Agent(7):Skills
前端·agent·cursor
nuIl42 分钟前
实现一个 Coding Agent(8):会话持久化与多会话
前端·agent·cursor
jt君424262 小时前
React Native JSI 深入剖析 — 第 5 部分中文技术整理:用 HostObject 把 C++ 类暴露给 JavaScript
前端·react native
胡萝卜术2 小时前
滑动窗口最大值:从暴力到单调队列,层层优化全解析
前端·javascript·面试
fluffyox2 小时前
Notion 的公式栏里,藏着一台虚拟机——逆向 + 用 600 行 JS 复刻它的编译器与栈式 VM
前端
kyriewen3 小时前
2026 年了,这 6 个 npm 包可以卸载了——浏览器原生 API 已经能替代
前端·javascript·npm
铁皮饭盒4 小时前
bun直接tsx,优雅!
javascript·后端