vueRouter的hash模式跟history的区别

vue-router 提供了两种常见的路由模式:hash 模式 和 history 模式。这两种模式的主要区别在于 URL 的表现形式、路由的工作机制、以及它们如何与浏览器的历史记录和后端服务器交互。

1. Hash 模式 (`#`)

工作原理:
Hash 模式 是通过 URL 中的 hash (`#`) 符号来管理路由。浏览器不会发送 hash 后的内容到服务器,而是由前端 JavaScript 处理 URL 中 hash 后的部分。
 例如,`http://example.com/#/home`,这里的 `#/home` 只是前端 JavaScript 处理的部分,服务器仅加载 `http://example.com/`。

 特点:
- 不需要服务器支持**:由于 hash 模式不会改变浏览器的实际路径,它不会向服务器发送请求,因此服务器无需特别配置支持。
- 兼容性:支持所有浏览器,包括较老版本的浏览器。
- 用户体验:用户刷新页面时,仍然能保持当前的 hash 路径,页面不会跳转到 404 页面。
- URL:在 URL 中,`#` 后面的部分不会被浏览器发送到服务器,这意味着 URL 中包含的 hash 值仅仅是客户端的路由状态。例如:`http://example.com/#/home`。
  
 示例:
javascript
const router = new VueRouter({
  mode: 'hash',
  routes: [
    { path: '/', component: Home },
    { path: '/about', component: About }
  ]
});
 

优缺点:
- 优点:
  - 配置简单,不需要额外的服务器配置。
  - 对于老旧浏览器也有良好的支持。
- 缺点:
  - URL 不够优雅,带有 `#` 符号。
  - 不利于 SEO(搜索引擎优化),因为很多爬虫不解析 `#` 后的内容。
  - 不支持浏览器的 "pushState" 和 "replaceState" 等历史记录 API,因此相对于 history 模式灵活性较差。

---

 2. History 模式 (`HTML5 history API`)

工作原理:
- History 模式 依赖于 HTML5 中的 `history.pushState()` 和 `history.replaceState()` API 来管理浏览器的历史记录。使用此模式时,URL 不会包含 `#`,而是表现为正常的路径,例如:`http://example.com/home`。
- 当用户点击浏览器的前进/后退按钮时,`vue-router` 会根据 URL 改变页面内容,但不会进行全页面的刷新。

 特点:
- 不包含 `#`:URL 更加简洁、优雅,符合传统的 RESTful 风格。
- 需要服务器支持:当用户直接刷新页面时,浏览器会向服务器发出请求。若刷新一个非根路径(例如:`/home`),服务器需要配置重定向或处理所有请求并返回同一个 HTML 文件,确保 Vue 应用能正常运行。如果服务器没有进行适当的配置,刷新可能导致 404 错误。
- SEO 友好:由于没有 hash 符号,URL 看起来更像传统的网站 URL,有助于 SEO,搜索引擎可以正确地解析和索引路径。

 示例:
javascript
const router = new VueRouter({
  mode: 'history',
  routes: [
    { path: '/', component: Home },
    { path: '/about', component: About }
  ]
});
 

 优缺点:
- 优点:
  - URL 清晰简洁,符合 RESTful 风格。
  - 支持现代浏览器的历史记录 API,具有更高的灵活性。
  - 更友好的 SEO 支持。
- 缺点:
  - 需要服务器配置支持。当用户直接访问一个非根路径(例如:`/home`)时,服务器需要确保返回正确的 HTML 文件,而不仅仅是返回 404 错误。
  - 对旧版浏览器(如 IE 9 以下)不支持 `history.pushState()`,需要 polyfill 或使用其他解决方案。

---

 3. 总结

| 特性                     | Hash 模式                                  | History 模式                                  |
|--------------------------|--------------------------------------------------|---------------------------------------------------|
| URL 显示              | 带 `#`,例如 `http://example.com/#/home`         | 无 `#`,例如 `http://example.com/home`            |
| 是否需要服务器支持    | 不需要                                          | 需要,服务器需要正确配置以处理非根路径          |
| SEO 友好              | 不太友好,搜索引擎通常无法解析 `#` 后的内容      | SEO 友好,搜索引擎能正确解析路径                |
| 兼容性                | 兼容所有浏览器,尤其是旧版本浏览器              | 现代浏览器支持较好,旧版浏览器不完全支持         |
| 用户体验              | 刷新页面时,hash 变化不会影响页面加载,易于管理   | 刷新页面时,服务器需要处理并返回 HTML 页面      |
| 历史记录              | 不支持历史记录 API 的细粒度控制                  | 支持 `history.pushState()` 和 `history.replaceState()` API,控制历史记录更灵活 |

选择建议:
- Hash 模式:适用于不需要 SEO 支持的应用,或者需要兼容旧版浏览器的场景。也适用于不希望或不能配置服务器的应用。
- History 模式:适用于现代 Web 应用,需要干净的 URL 和更好的 SEO 支持的场景,但需要配置服务器处理路由。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/42756.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

记一次系统单点登录、模拟web系统登录方式的开发过程,使用AES加密

1.系统原始登录方式 访问登录页 输入账号密码登录后 2.从登录页找进去,从代码层面查看系统登录逻辑 常规登录方式为前端ajax请求LoginService服务-->返回200则跳转到home系统首页 查看LoginService登录逻辑 后台获取ajax传递的信息-->比较验证码-->查询…

iPhone mini,永远再见了

世界属于多数派,尽管有极少数人对 iPhone mini 情有独钟,但因为销量惨淡,iPhone mini 还是逃不开停产的命运。 据 Counterpoint 的数据,iPhone 12/13 mini 两代机型,仅占同期 iPhone 销量的 5%。 因为是小屏手机&…

监控易一体化运维:监控易机房管理,打造高效智能机房

在数字化浪潮中,企业对数据中心和机房的依赖程度与日俱增,机房的稳定运行成为业务持续开展的关键支撑。信息化的变迁,见证了机房管理从传统模式向智能化、精细化转变的过程。今天,就为大家深度剖析监控易在机房管理方面的卓越表现…

概率与决策理论

1.Q-learning Q-Learning 是一种无模型(model-free)强化学习算法,用于学习在马尔可夫决策过程(MDP)中的最优策略。它通过迭代更新 ​Q 值(动作价值函数)​ 来估计在某个状态下采取某个动作的长…

Python 学习路线推荐

文章目录 一、基础语法学习1.学习资源2.学习建议 二、数据处理与分析方向1. 数据处理库学习学习资源实践示例 2. 数据可视化实践示例 三、Web 开发方向1. Web 框架选择与学习学习资源实践示例 2. 前端知识补充学习资源 四、人工智能与机器学习方向1. 机器学习基础学习资源实践示…

如何让DeepSeek-R1在内网稳定运行并实现随时随地远程在线调用

前言:最近,国产AI圈里的新星——Deepseek,简直是火到不行。但是,你是不是已经对那些千篇一律的手机APP和网页版体验感到腻味了?别急,今天就带你解锁一个超炫的操作:在你的Windows电脑上本地部署…

SpringCloud+Mybatis-Plus+Docker+RabbitMQ+Redis+Elasticsearch黑马商城

一.MyBatis—Plus 一.快速入门 MybatisPlus介绍:MybatisPlus是一个基于Mybatis的增强工具库,旨在简化开发、提升效率,同时保留Mybatis的灵活性。它在Mybatis的基础上只做增强不做改变,引入它不会对现有工程产生影响 官网&#…

01 相机标定与相机模型介绍

学完本文,您将了解不同相机模型分类、内参意义,及对应的应用代码模型 标定的意义 建模三维世界点投影到二维图像平面的过程。标定输出的是相机模型。 相机模型 相机模型可以解理解为投影模型 +

如何在 Postman 中正确设置 Session 以维持用户状态?

在 Postman 里面设置有 session 的请求。如果你还不知道什么是 session,那么请看这里—— session 是一种记录客户端和服务器之间状态的机制,用于保持用户的登录状态或者其他数据,从而让用户在不同页面之间保持一致的体验。 Postman 设置带 …

免费使用!OpenAI 全量开放 GPT-4o 图像生成能力!

2025年3月26日,OpenAI正式推出GPT-4o原生图像生成功能,这一更新不仅标志着多模态AI技术的重大突破,更引发了全球AI厂商的激烈竞争。从免费用户到企业开发者,从创意设计到科学可视化,GPT-4o正在重塑图像生成的边界。本文…

【JavaScript】八、对象

文章目录 1、对象的声明2、对象的使用3、对象中的方法4、遍历对象5、内置对象Math 1、对象的声明 一种数据类型,使用typeof查看类型,结果是object可以详细的描述描述某个事物 声明语法: // 多用花括号形式声明 // 比如声明一个person对象 …

C++指针(五)完结篇

个人主页:PingdiGuo_guo 收录专栏:C干货专栏 前言 相关文章:C指针(一)、C指针(二)、C指针(三)、C指针(四)万字图文详解! 本篇博客是介…

DataGear 企业版 1.4.0 发布,数据可视化分析平台

DataGear 企业版 1.4.0 已发布,欢迎体验! http://datagear.tech/pro/ 企业版 1.4.0 看板可视编辑模式新增了插入看板表单/面板布局、编辑图表联动、复制/粘贴、撤销/恢复等功能,具体更新内容如下: 新增:看板可视编辑…

windows第十八章 菜单、工具栏、状态栏

文章目录 创建框架窗口菜单菜单的风格通过资源创建菜单菜单的各种使用通过代码创建菜单在鼠标位置右键弹出菜单 CMenu常用函数介绍工具栏方式一,从资源创建工具栏方式二,代码创建 状态栏状态栏基础创建状态栏 创建框架窗口 手动创建一个空项目&#xff…

局域网共享失败?打印机/文件夹共享工具

很多时候,在办公或家庭环境中,我们需要进行打印机和文件夹的共享,以便更高效地协作和处理文件。然而,寻找对应版本的共享设置或是不想花费太多时间去进行复杂的电脑设置,总是让人感到头疼。今天,我要向大家…

C++中使用CopyFromRecordset将记录集拷贝到excel中时,如果记录集为0个,函数崩溃,是什么原因

文章目录 原因分析解决方案1. 检查记录集是否为空2. 安全调用COM方法3.进行异常捕获4. 替代方案:手动处理空数据 总结 在C中使用CopyFromRecordset将空记录集(0条记录)复制到Excel时崩溃的原因及解决方法如下: 原因分析 空记录集…

torchvision中数据集的使用

1、torchvision及其数据集的介绍 1.1 torchvision介绍 torchvision 是 PyTorch 的一个官方库,专门用于计算机视觉任务。它提供了以下核心功能: 预训练模型:如 ResNet、VGG、EfficientNet 等。数据集:内置常用视觉数据集&#xf…

d2025328

一、sql-判断三角形 610. 判断三角形 - 力扣&#xff08;LeetCode&#xff09; 用一下if加上判断条件 select x,y,z,if(xy > z and xz > y and yz > x and x-y < z and x-z < y and y-z < x,Yes,No) as triangle from Triangle 二、按照分类统计薪水 190…

C++20新特性:std::assume_aligned详解

文章目录 一、概述二、函数定义与语法三、使用方法与注意事项1. 使用方法2. 注意事项 四、性能优化原理五、实际应用场景六、编译器支持情况七、总结 一、概述 C20引入了std::assume_aligned&#xff0c;这是一个非常实用的特性&#xff0c;用于告知编译器某个指针所指向的对象…

洛谷P1706 全排列题解

P1706 全排列问题 题目描述 按照字典序输出自然数 1 1 1 到 n n n 所有不重复的排列&#xff0c;即 n n n 的全排列&#xff0c;要求所产生的任一数字序列中不允许出现重复的数字。 输入格式 一个整数 n n n。 输出格式 由 1 ∼ n 1 \sim n 1∼n 组成的所有不重复的…