Vue Router 路由hash和history模式

文章目录

  • hash和history模式区别
  • Hash 模式
  • History 模式

在 Vue 中,路由的两种主要模式是 hashhistory,默认的路由模式是hash模式。。这两种模式决定了 URL 的外观以及浏览器如何处理 URL 的变化。


hash和history模式区别

特性Hash 模式History 模式
URL 表现形式URL 中带有 # 符号,如 http://example.com/#/aboutURL 看起来更干净,没有 # 符号,如 http://example.com/about
服务器配置不需要特殊的服务器配置需要服务器配置以支持客户端路由,返回 index.html
兼容性所有现代浏览器都支持大多数现代浏览器都支持,但在一些较旧的浏览器或特殊环境中可能不支持
美观度URL 中带有 # 符号可能看起来不太美观URL 看起来更干净,没有额外的符号
SEO# 后面的内容不会被搜索引擎视为页面的一部分与常规页面一样,可以被搜索引擎索引
书签书签中的 URL 会包含 # 符号书签中的 URL 更简洁
刷新页面刷新页面时,通常能够保持当前路由状态如果没有正确的服务器配置,刷新页面可能会返回 404 错误
浏览器前进/后退按钮正常工作正常工作
配置方式Vue Router 默认使用 Hash 模式需要在创建 Vue Router 实例时明确指定 mode: 'history'

Hash 模式

hash值会出现在URL里面,但是不会出现在HTTP请求中,对后端完全没有影响。所以改变hash值,不会重新加载页面。这种模式的浏览器支持度很好,低版本的IE浏览器也支持这种模式。hash路由被称为是前端路由,已经成为SPA(单页面应用)的标配。

特点:

  • URL 中会带有一个 # 号,例如 http://example.com/#/home
  • 浏览器不会将带有 # 及其后面的部分发送到服务器请求资源
  • 仅改变 # 后面的部分,不会重新加载页面
  • 兼容性较好,所有现代浏览器都支持

切换到hash模式:

  • Vue2.x中:

    const router = new VueRouter({
      mode: 'hash',
      routes
    })
    
  • Vue3.x中:

    const router = createRouter({
        history: createWebHashHistory(),
        routes
    });
    

hash模式的主要原理就是onhashchange()事件:

window.onhashchange = function(event){
	console.log(event.oldURL, event.newURL);
	let hash = location.hash.slice(1);
}

使用onhashchange()事件的好处就是,在页面的hash值发生变化时,无需向后端发起请求,window就可以监听事件的改变,并按规则加载相应的代码。

除此之外,hash值变化对应的URL都会被浏览器记录下来,这样浏览器就能实现页面的前进和后退。虽然是没有请求后端服务器,但是页面的hash值和对应的URL关联起来了。


History 模式

history模式的URL中没有#,它使用的是传统的路由分发模式,即用户在输入一个URL时,服务器会接收这个请求,并解析这个URL,然后做出相应的逻辑处理。

虽然history模式丢弃了丑陋的#。但是,它也有自己的缺点,就是在刷新页面的时候,如果没有相应的路由或资源,就会刷出404来。

特点:

  • URL 看起来更加“干净”,没有 # 号,例如 http://example.com/home
  • 浏览器会将 URL 的变化当作一个普通的页面跳转,可能会向后端服务器发起请求
  • 需要后端进行配置,以便对所有路由都返回同一个页面(通常是 index.html),否则就会404
  • 兼容性相对较差,IE9 以下不支持

切换到history模式:

  • Vue2.x中:

    const router = new VueRouter({
      mode: 'history',
      routes: [...]
    })
    
  • Vue3.x中:

    const router = createRouter({
        history: createWebHistory(),
        routes
    });
    

后端配置:

当使用 history 模式时,需要确保后端服务器对所有路由都返回同一个页面(通常是 index.html)。
以下是一个 Nginx 的配置示例:

location / {  
  try_files $uri $uri/ /index.html;  
}

这个配置告诉 Nginx,如果请求的文件或目录不存在($uri 和 $uri/ 都不匹配),就返回 index.html。
这样,无论用户访问哪个 URL,都会返回 Vue 应用的入口文件,然后由 Vue Router 接管后续的路由处理。

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

巡检机器人有哪些功能和作用?

在科技如此发达的时代,巡检机器人犹如一位不知疲倦的守护者,悄然走进了我们的生活。它们具备着令人惊叹的功能和作用,成为了保障安全、提高效率的重要力量。那么,巡检机器人功能和作用?下面我们来说说旗晟机器人的几款…

faad2交叉编译——aac解码为pcm,解决faad单通道转双通道问题

FAAD是比较成熟高效的开源AAC解码库,这里用于解码AAC生成PCM数据,用于音频播放。这里因为faad库,会将单通道转化为双通道踩了些坑,所以记录一下。 我使用的是2.11.0版本,貌似往前的版本没有使用CMake,需要c…

自动化测试:Selenium入门指南!

Selenium是一个强大的自动化测试工具,特别适用于Web应用测试。本指南将介绍Selenium的安装、常用功能以及一些常见方法,帮助入门并能够更灵活地进行自动化测试。Selenium是一个用于自动化浏览器操作的工具,它广泛应用于Web应用程序的测试和网…

【前缀和】560. 和为 K 的子数组 974. 和可被 K 整除的子数组

题目链接 974. 和可被 K 整除的子数组 560. 和为 K 的子数组 今天刷题的时候,刷了这两题,感觉挺有意思的。代码写起来挺简单的,但是思路和其中的细节以及涉及到的知识点确实让我挺意外的。这里写个博客解析一波,也是巩固一下。 力…

分享《2024年中国企业级SaaS行业研究报告》

(文章作者与来源:艾瑞咨询) 大浪淘沙,SaaS行业进入关键转折点,企业级SaaS的总体市场规模达到888亿元,同比增长13.0%。内外部因素叠加之下,预计三年未来企业级SaaS市场规模的增速将稳定在15%-20…

请大数据把我推荐给正在申请小程序地理位置接口的人

小程序地理位置接口有什么功能? 若提审后被驳回,理由是“当前提审小程序代码包中地理位置相关接口( chooseAddress、getLocation )暂未开通,建议完成接口开通后或移除接口相关内容后再进行后续版本提审”,那么遇到这种情况&#x…

2024速通python之python基础

文章目录 一、你好,世界二、基本数据类型(1)数字型(2)字符串(3)列表(4)元组(5)集合(6)字典 二、注释(1&#x…

【面试干货】http请求报文的组成与作用?

【面试干货】http请求报文的组成与作用? 一、http 的请求报文组成二、请求行(Request Line)三、请求头部(Request Headers)四、请求体(Request Body)五、响应头部 (Response Headers…

LeetCode70:爬楼梯

题目描述 假设你正在爬楼梯。需要 n 阶你才能到达楼顶。 每次你可以爬 1 或 2 个台阶。你有多少种不同的方法可以爬到楼顶呢? 解题思想 1.确定dp数组以及下标的含义 dp[i]: 爬到第i层楼梯,有dp[i]种方法 2.确定递推公式 从dp[i]的定义可以…

Ansible任务剧本Playbook之变量、模板、角色介绍

前言 上篇介绍了 Ansible 单模块(AD-Hoc)的相关内容Ansible自动化运维工具单模块介绍-CSDN博客,Ad-Hoc 命令是一次性的、即时执行的命令,用于在远程主机上执行特定任务,这些命令通常用于快速执行简单的任务。当需要在…

【AI绘画】Midjourney 工笔画 水蓝色衣服的少女

using Midjourney 提示词: highly detailed,细节刻画细腻,超高清晰度,32k,HD,大师作品,高质量,动漫少女,水墨人像,20岁年轻身材很好的中国少女,惊人的美貌,五官精致,精致的妆容,华丽的水蓝色衣服,古风服饰,华丽的珠宝,飞扬的黑色长发,大风吹起头发,宝石发光,黄金装饰…

如何给正弦信号添加12V直流偏置

一个有趣问题的探究: 运放在单电源的情况下只能输出正电压(单方向的),这就使得有正负值的信号电压只能输出一半: 【单电源供电的运放如何增加直流偏置】(电阻分压法): 单电源供电的…

某云eHR PtFjk.mob 任意文件上传漏洞复现

0x01 产品简介 某云eHR是大中型企业广泛采用人力资源管理系统。某云是国内顶尖的HR软件供应商,是新一代eHR系统的领导者。 0x02 漏洞概述 某云EHR系统PtFjk.mob接口处存在未授权文件上传漏洞,攻击者可上传webshell来命令执行,获取服务器权限。 0x03 复现环境 FOFA:bod…

算法-并查集

目录 什么是并查集 并查集基础 (1)原理 (2)初始化 (3)查询 (4)合并 (5)判断是否同一集合 并查集优化 路径压缩 启发式合并 并查集模板 模板 例题…

线下订单平台操作步揍

收款管理 1微信收款查询 1. 获取微信数据 获取微信数据。通过时间范围 查找微信数据调用第三方接口如下: Map map HttpPost.doPost("https://qyapi.weixin.qq.com/cgi-bin/externalpay/get_bill_list?access_token"ApiUtils.getWxtoken(),args); 其中…

如何缩小图片尺寸不改变清晰度?几个方法教你解决

在平时对图片进行处理的时候,最害怕的就是修改过的图片质量下降,导致清晰度不够,尤其是缩小图片尺寸的时候,所以今天小编就来告诉大家几个关于修改图片尺寸又不改变清晰度的方法。 修改图片大小是非常普遍的图片编辑需求&#xf…

【SpringMVC 】什么是SpringMVC(三)?基于springmvc的文件上传、基于springmvc的拦截器、基于springmvc的邮件发送

文章目录 SpringMVC第五章1、SpringMVC文件上传1、基本步骤1-2345-82、邮件发送1、基本步骤1-234-5567-8 简单邮件带附件的邮件第六章1、拦截器的使用使用步骤232、调度的使用基本步骤1-56-8调度规则3、shiro安全框架核心概念基本语法1、基于ini文件的认证**测视类**2、基于rea…

计算机组成原理网课笔记

无符号整数的表示与运算 带符号整数的表示与运算 原反补码的特性对比 移码

基于 docker-compose 部署 LNMP 架构

目录 前言 1、任务要求 2、Nginx 2.1 建立工作目录并上传相关安装包 2.2 编写 Nginx Dockerfile 脚本 2.3 准备 nginx.conf 配置文件 3、Mysql 3.1 建立工作目录并上传相关安装包 3.2 编写 Mysql Dockerfile 脚本 3.3 编写 my.cnf 配置文件 4、PHP 4.1 建立工作目录…
最新文章