当前位置: 首页 > news >正文

hash模式和history模式

在Vue Router中,有两种路由模式可供选择:hash模式和history模式。它们各自有一些优点和缺点,下面是它们的简要介绍:

  • hash模式的原理是通过hashchange事件,通过监听hash变化来驱动界面变化。它的url中有 # 号

  •   1、监听地址栏中hash变化驱动界面变化2、用pushsate记录浏览器的历史,驱动界面发送变化
    
  • history模式的原理是通过popstate事件,通过监听浏览器历史记录变化来驱动界面变化。
    需要注意的是调用history.pushState()或history.replaceState()不会触发popstate事件。

  • 只有在做出浏览器动作时,才会触发该事件,如用户点击浏览器的回退按钮(或者在Javascript代码中调用history.back())它的url中没有 # 号

  • 项目上线之后,需要在后端服务器额外配置,否则会出现404错误

  •  history 模式核心借用 HTML5 history api,api 提供了丰富的 router 相关属性先了解一个几个相关的 apipushState 向浏览器历史纪录添加记录replaceState修改浏览器历史纪录中当前纪录popState 事件, 当 history 发生变化时触发
    

Hash模式:

优点:

  • 兼容性好:Hash模式使用URL中的哈希值(#)来模拟路由,不会触发页面的刷新,因此在各种浏览器和服务器环境下都能正常工作。
  • 简单配置:不需要服务器端的特殊配置,只需在前端配置即可。

缺点:

  • URL不美观:由于使用哈希值,URL中会出现#符号,对于用户来说不够友好。
  • 有一定冗余:每次路由切换时,URL中的哈希值会发生变化,但页面不会刷新,这可能会导致一些冗余的哈希值出现在URL中。

History模式:

优点:

  • URL美观:History模式使用真实的URL路径,没有#符号,对于用户来说更加友好。
  • 无冗余:每次路由切换时,URL路径会发生变化,但页面不会刷新,不会出现冗余的URL。

缺点:

  • 兼容性较差:History模式依赖HTML5的History API,不支持的浏览器会导致路由无法正常工作。需要服务器端的特殊配置,以确保在路由- 刷新时能正确返回对应的页面。
  • 需要后端支持:当用户直接访问History模式下的URL时,需要服务器端正确配置,以返回对应的页面,否则会导致404错误。

选择使用哪种模式取决于你的项目需求和实际情况。如果你的项目需要兼容性好且不需要美观的URL,可以选择Hash模式。如果你的项目追求更美观的URL,并且能够进行服务器端配置,可以选择History模式。

相关文章:

hash模式和history模式

在Vue Router中,有两种路由模式可供选择:hash模式和history模式。它们各自有一些优点和缺点,下面是它们的简要介绍: hash模式的原理是通过hashchange事件,通过监听hash变化来驱动界面变化。它的url中有 # 号 1、监听…...

聊聊logback的LevelFilter

序 本文主要研究一下logback的LevelFilter AbstractMatcherFilter ch/qos/logback/core/filter/AbstractMatcherFilter.java public abstract class AbstractMatcherFilter<E> extends Filter<E> {protected FilterReply onMatch FilterReply.NEUTRAL;protect…...

mysql 行转列 GROUP_CONCAT 试验

1.概要 很多时候需要用到行专列的方式做数据分析。比如对通讯数据的采集 数据采集结果如下&#xff1a; 变量值采集周期131251132272 我想要看的结果 变量1变量2采集周期351372 就是我想看到相关数据的周期变化情况。 2.试验 2.1创建数据如下&#xff08;表名 tb5&…...

HarmonyOS元服务开发实战—端云一体化开发

还记得我第一次接触arkui还是在22年的9月份&#xff0c;当时arkui还在一个比较初试的阶段。时隔一年再见方舟框架&#xff0c;它已经发生了令人瞩目的变化&#xff0c;不得不说华为方舟框架在更新迭代的速度已经遥遥领先。新的功能和性能优化让这个框架更加强大和灵活&#xff…...

【搭环境】装Python3.8 open3d

先装Python3.8 方法一试了找不到Python3.8的库&#xff0c;所以用方法二装上了。 Python3加入环境变量 更改Python默认指向 open3d需要Python3.6以上&#xff0c;最好用Ubuntu18版本&#xff0c;我用的16版本。。...

【C语言】深入解开指针(四)

&#x1f308;write in front :&#x1f50d;个人主页 &#xff1a; 啊森要自信的主页 ✏️真正相信奇迹的家伙&#xff0c;本身和奇迹一样了不起啊&#xff01; 欢迎大家关注&#x1f50d;点赞&#x1f44d;收藏⭐️留言&#x1f4dd;>希望看完我的文章对你有小小的帮助&am…...

AMEYA360:瑞萨面向高端工业传感器系统推出高精度模拟前端的32位RX MCU

全球半导体解决方案供应商瑞萨电子&#xff08;TSE&#xff1a;6723&#xff09;宣布面向高端工业传感器系统推出一款全新RX产品——RX23E-B&#xff0c;扩展32位微控制器&#xff08;MCU&#xff09;产品线。新产品作为广受欢迎的RX产品家族的一员&#xff0c;具有高精度模拟前…...

切面Aspect + 策略模式实现待办提醒功能

1.背景 产品需要实现一个待办提醒功能&#xff0c;就是核心业务发生变更即提醒业务员去处理相关业务。譬如&#xff1a;订单上传了支付凭证&#xff0c;那么就会提醒相关业务员去待办列表操办。 2.表设计 其实表设计主要是两张表sys_todo、sys_todo_detail 一张是待办核心表…...

SAP 调取http的x-www-form-urlencoded形式的接口

一、了解下x-www-form-urlencoded形式对于SAP来说有啥区别 简单来说&#xff0c; 1.raw格式就是标准的json格式&#xff1a;{“Name”:“John Smith”&#xff0c;“Age”: 23} 2.x-www格式是要转化一下的&#xff1a;NameJohnSmith&Age23 字段与字段相互连接要用 & 符…...

thingsboard3.6的mailConfigTemplateController错误

1、bug内容 使用3.6版本的tb代码进行打包生成boot的jar包,在启动的时候会报错mailConfigTemplateController bean初始化找不到文件路径。 Error creating bean with name mailConfigTemplateController defined in URL [jar:file:/D:/yuxinwei/AE/thingsboard/thingsboard-3…...

Go语言中获取IP

简介 在net包中提供了获取所有网卡的ip&#xff0c;一般不会用127.0.0.1,::1这样的本地回环地址&#xff0c;可以过滤掉&#xff0c;如果想要获取当前真正在使用的地址&#xff0c;得通过net.Dail去连一下才知道 获取ip地址 func main() {fmt.Println(getIpv4())fmt.Println…...

【Computer Vision Foundation】全球计算机视觉基金会论文网

计算机视觉基金会&#xff08;Computer Vision Foundation&#xff0c;简称CVF&#xff09;是一个致力于推动计算机视觉领域研究和发展的组织。以下是关于计算机视觉基金会的一些基本信息&#xff1a; 成立目的&#xff1a; CVF成立的目的是促进计算机视觉领域的学术研究、技术…...

计网(复习自用)

计算机网络 1.概述 1.1概念 含义 计算机网络&#xff1a;是一个将分散的。具有独立功能的计算机系统&#xff0c;通过通信设备和线路连接起来&#xff0c;由功能完善的软件实现资源共享和信息传递的系统。 简单点说&#xff0c;计算机网络是互联的&#xff0c;自治的计算机集…...

安徽省广德市选择云轴科技ZStack Cloud云平台建设县级智慧城市

信创是数字中国建设的重要组成部分&#xff0c;也是数字经济发展的关键推动力量。作为云基础软件企业&#xff0c;云轴科技ZStack产品矩阵全面覆盖数据中心云基础设施&#xff0c;ZStack信创云首批通过可信云《一云多芯IaaS平台能力要求》先进级&#xff0c;是其中唯一兼容四种…...

【计算思维】蓝桥杯STEMA 科技素养考试真题及解析 6

1、明明买了一个扫地机器人&#xff0c;可以通过以下指令控制机器人运动: F:向前走 10 个单位长度 L:原地左转 90 度 R:原地右转 90 度 机器人初始方向向右&#xff0c;需要按顺序执行以下那条指令&#xff0c;才能打扫完下图中的道路 A、F-L-F-R-F-F-R-F-L-F B、F-R-F-L-F-F…...

nuxt3项目修改端口号

nuxt的默认端口号是3000 一、修改开发环境端口号 方式一&#xff1a;使用环境变量配置,设置&#xff08;PORT 或 NUXT_PORT&#xff09; # .env PORT3001 #http://localhost:3001/ NITRO_PORT3001 #http://localhost:3001/ 方式二&#xff1a;nuxt.config.ts里配置…...

c语言中使用openssl对rsa私钥解密

单次加密数据的最大长度&#xff08;block_len&#xff09;&#xff0c;由RSA秘钥模长RSA_size()和填充模式有关 填充模式&#xff1a;RSA_PKCS1_PADDING&#xff0c; block_lenRSA_size() - 11填充模式&#xff1a;RSA_PKCS1_OAEP_PADDING&#xff0c;block_lenRSA_size() - 4…...

mysql中数据是如何被用B+树查询到的

innoDB是按照页为单位读写的 那页中有很多行数据&#xff0c;是怎么执行查询的呢&#xff0c;首先我们肯定&#xff0c;是以单向列表形式存储的&#xff0c;提高了增删的效率&#xff0c;但是查询效率低。所以实际上对页中的行数据进行了优化&#xff0c;能以二分的方式进行查…...

Redisson 分布式锁的最佳实践

Redisson 分布式锁的最佳实践 第一、添加依赖第二、添加redisson配置类第三、添加测试类测试结果扩展知识redisson锁中lock方法和tryLock方法有什么区别锁续约 注意事项 引言 在现代分布式系统中&#xff0c;处理并发问题是至关重要的。分布式锁是解决这类问题的关键工具之一。…...

ArkTS声明式开发范式

装饰器 用来装饰类、结构体、方法以及变量&#xff0c;赋予其特殊的含义&#xff0c;如上述示例中 Entry 、 Component 、 State 都是装饰器。 Component 表示这是个自定义组件&#xff1b; Entry 则表示这是个入口组件&#xff1b; State 表示组件中的状态变量&#xff0c;…...

如何每天节省25分钟:淘金币自动化脚本终极指南

如何每天节省25分钟&#xff1a;淘金币自动化脚本终极指南 【免费下载链接】taojinbi 淘宝淘金币自动执行脚本&#xff0c;包含蚂蚁森林收取能量&#xff0c;芭芭农场全任务&#xff0c;解放你的双手 项目地址: https://gitcode.com/gh_mirrors/ta/taojinbi 还在为每天重…...

告别Hello World!用PySide6从零搭建一个简易桌面待办事项App(附完整源码)

用PySide6打造高颜值桌面待办事项应用&#xff1a;从设计到打包的完整指南 每次看到那些花哨的任务管理工具&#xff0c;总觉得它们要么功能过剩&#xff0c;要么界面复杂。作为开发者&#xff0c;我们完全可以用PySide6亲手打造一个简约高效的待办事项应用。这不仅是掌握GUI开…...

第97篇:联邦学习原理与应用——如何在保护隐私的前提下协同训练AI?(原理解析)

文章目录现象引入&#xff1a;数据孤岛与AI的“囚徒困境”提出问题&#xff1a;不移动数据&#xff0c;如何训练模型&#xff1f;原理剖析&#xff1a;联邦平均算法与隐私保护机制1. 联邦平均的核心步骤2. 隐私保护的两道防线源码印证&#xff1a;从伪代码到框架实践实际影响&a…...

新概念英语第二册59_In or out

Lesson 59: In or out?Key words and expressions Rex 雷克斯bark v. 狗叫press 按&#xff0c;压paw 脚爪latch 门闩expert 专家develop a habit 养成习惯remove 拆掉&#xff0c…...

UP 7000 SBC工业级单板计算机评测与实战指南

1. UP 7000 SBC开箱与硬件解析作为一款面向工业应用的信用卡尺寸单板计算机&#xff0c;UP 7000搭载了Intel Alder Lake-N架构的N100处理器。这款四核处理器采用10nm工艺&#xff0c;基础频率700MHz&#xff0c;最大睿频3.4GHz&#xff0c;配备2MB L2和6MB L3缓存。我拿到的评测…...

别再为433MHz天线尺寸发愁了:三种PCB小型化实战方案对比(曲流/加载/高介电材料)

433MHz PCB天线小型化设计&#xff1a;三大技术方案深度解析与工程实践 在物联网设备与智能硬件蓬勃发展的今天&#xff0c;433MHz频段因其良好的穿透性和适中的传输距离&#xff0c;依然是无线遥控、智能家居传感器、工业监测等场景的首选。然而&#xff0c;传统四分之一波长天…...

【AI工程化硬核警告】:PHP 9.0正式支持Fibers原生异步,但87.6%的AI机器人因未重写Promise调度器已悄然降级为同步阻塞

更多请点击&#xff1a; https://intelliparadigm.com 第一章&#xff1a;PHP 9.0异步演进与AI机器人性能断崖的真相 PHP 9.0 并非官方已发布的版本&#xff08;截至 2024 年&#xff0c;PHP 官方最新稳定版为 8.3&#xff09;&#xff0c;但社区中广泛流传的“PHP 9.0”概念实…...

你还在用Worker进程模拟并发?PHP 8.9 原生纤维协程已支持调度器热插拔(仅限RC3+内测通道开放)

更多请点击&#xff1a; https://intelliparadigm.com 第一章&#xff1a;PHP 8.9 纤维协程高并发实战导论 PHP 8.9&#xff08;预发布版&#xff09;首次将 Fiber&#xff08;纤维&#xff09;原生协程能力深度整合至引擎层&#xff0c;无需依赖扩展或用户态调度器&#xff0…...

技术返祖运动:软件测试中的传统智慧回归

在数字技术飞速发展的时代&#xff0c;软件测试从业者面临前所未有的挑战&#xff1a;系统复杂性剧增、数据过载和认知疲劳。技术返祖运动应运而生&#xff0c;它并非简单的历史倒退&#xff0c;而是战略性地回归传统方法&#xff0c;以应对现代测试生态的脆弱性。这场运动的核…...

手把手教你学 Simulink——基于 Simulink 的 智能四驱扭矩分配与能效优化

目录 手把手教你学 Simulink 一、引言:从“整体驱动”到“分布式驱动”——为什么需要智能扭矩分配? 二、被控对象:车辆动力学模型 A. 三自由度自行车模型(Simulink 实现) 三、控制架构:分层式设计 四、Step 1:上层控制器设计 A. 纵向控制器(PID) B. 横摆控制器…...