文章目录

      • 一、路由配置相关
      • 二、路由实例方法(`router` 实例)
      • 三、组件内路由 API(`useRouter` / `useRoute`)
      • 四、导航守卫(路由拦截)
      • 五、路由视图与导航组件
      • 六、其他常用 API
      • 七、history模式和hash模式有什么区别?
        • 1. URL 格式不同
        • 2. 底层实现原理不同
        • 3. 服务器配置要求不同
        • 4. 功能限制不同
        • 5、如何选择?
        • 6、模式切换方式

Vue Router 是 Vue 官方的路由管理库,提供了丰富的 API 用于处理路由配置、导航控制、参数传递等功能。以下是其常用 API 的分类整理:

一、路由配置相关

  1. createRouter
    创建路由实例的核心函数,接收 historyroutes 配置:

    import { createRouter, createWebHistory } from 'vue-router'
    const router = createRouter({history: createWebHistory(), // 路由模式routes: [/* 路由规则数组 */]
    })
    
  2. createWebHistory / createWebHashHistory
    定义路由模式:

    • createWebHistory():HTML5 History 模式(无 #,需服务端配置)
    • createWebHashHistory():Hash 模式(带 #,无需服务端配置)
  3. 路由规则配置(routes 数组元素)
    每个路由对象的常用属性:

    • path:路由路径(如 /home
    • name:路由名称(用于命名路由跳转)
    • component:对应组件(如 Home
    • children:嵌套路由(子路由配置)
    • props:是否将路由参数转为组件 props(true / 对象 / 函数)
    • meta:自定义元数据(如 { requiresAuth: true } 用于权限控制)

二、路由实例方法(router 实例)

  1. router.push()
    导航到新路由(类似 window.location.href):

    // 字符串路径
    router.push('/home')
    // 命名路由 + 参数
    router.push({ name: 'user', params: { id: 1 } })
    // 查询参数
    router.push({ path: '/search', query: { q: 'vue' } })
    
  2. router.replace()
    导航到新路由,但不会向历史记录添加新条目(替换当前记录):

    router.replace('/about')
    
  3. router.go(n)
    操作历史记录(类似 window.history.go(n)):

    router.go(1)  // 前进一页
    router.go(-1) // 后退一页
    
  4. router.addRoute() / router.removeRoute()
    动态添加/删除路由:

    // 添加路由
    router.addRoute({ path: '/new', component: NewComponent })
    // 删除路由(通过名称)
    router.removeRoute('new')
    

三、组件内路由 API(useRouter / useRoute

  1. useRouter()
    在组件中获取路由实例(用于调用导航方法):

    import { useRouter } from 'vue-router'
    const router = useRouter()
    const goHome = () => router.push('/home')
    
  2. useRoute()
    在组件中获取当前路由信息对象(包含路径、参数等):

    import { useRoute } from 'vue-router'
    const route = useRoute()
    // 当前路径
    console.log(route.path)
    // 路由参数(params)
    console.log(route.params.id)
    // 查询参数(query)
    console.log(route.query.q)
    // 元数据
    console.log(route.meta.requiresAuth)
    

四、导航守卫(路由拦截)

  1. 全局守卫

    • router.beforeEach((to, from, next) => { ... })
      路由跳转前触发(常用于登录鉴权):
      router.beforeEach((to, from, next) => {if (to.meta.requiresAuth && !isLogin) {next('/login') // 未登录则跳转到登录页} else {next() // 允许跳转}
      })
      
    • router.afterEach((to, from) => { ... })
      路由跳转后触发(常用于页面标题设置)。
  2. 路由独享守卫
    在路由规则中定义 beforeEnter

    {path: '/admin',component: Admin,beforeEnter: (to, from, next) => {// 仅对当前路由生效的拦截逻辑}
    }
    
  3. 组件内守卫
    组件内定义的路由钩子:

    • beforeRouteEnter:进入组件前触发(此时组件实例未创建,无 this
    • beforeRouteUpdate:组件复用(路由参数变化)时触发
    • beforeRouteLeave:离开组件前触发(常用于未保存数据提示)

五、路由视图与导航组件

  1. <router-view>
    路由出口,用于渲染匹配的组件:

    <!-- 基础用法 -->
    <router-view />
    <!-- 命名视图(用于同时渲染多个组件) -->
    <router-view name="sidebar" />
    
  2. <router-link>
    路由导航组件(生成 <a> 标签,避免页面刷新):

    <!-- 基础用法 -->
    <router-link to="/home">首页</router-link>
    <!-- 命名路由 -->
    <router-link :to="{ name: 'user', params: { id: 1 } }">用户</router-link>
    <!-- 替换当前历史记录 -->
    <router-link to="/about" replace>关于</router-link>
    

六、其他常用 API

  • router.resolve():解析路由地址,返回路由信息对象。
  • router.hasRoute():检查路由是否存在(通过名称)。
  • router.getRoutes():获取所有路由记录的数组。
  • scrollBehavior:路由跳转时的滚动行为配置(在 createRouter 中定义)。

七、history模式和hash模式有什么区别?

Vue Router 中的 history 模式和 hash 模式是两种不同的路由实现方式,主要区别体现在 URL 格式、底层原理、服务器配置等方面,具体如下:

1. URL 格式不同
  • hash 模式(默认):
    URL 中包含 # 符号,# 后面的部分为路由路径。例如:
    http://example.com/#/homehttp://example.com/#/user/123
    # 及其后面的内容不会被发送到服务器,仅用于客户端路由解析。

  • history 模式
    URL 中不包含 #,使用标准的 HTML5 History API 实现。例如:
    http://example.com/homehttp://example.com/user/123
    看起来更接近传统的 URL,视觉上更友好。

2. 底层实现原理不同
  • hash 模式
    基于浏览器的 hashchange 事件实现。当 # 后面的路径变化时,浏览器不会重新请求页面,但会触发 hashchange 事件,Vue Router 监听该事件并切换对应组件。
    优点:兼容性好(支持所有现代浏览器及 IE8+),无需服务器配置。

  • history 模式
    基于 HTML5 的 history.pushState()history.replaceState() 方法(属于 History API)。这些方法可以在不刷新页面的情况下修改浏览器历史记录,Vue Router 通过监听历史记录变化实现路由切换。
    优点:URL 更美观,符合用户对 URL 的直观认知。
    缺点:兼容性稍差(仅支持 IE10+),且需要服务器配合配置。

3. 服务器配置要求不同
  • hash 模式
    无需特殊配置。因为 # 后面的内容不会发送到服务器,无论访问 http://example.com/#/home 还是 http://example.com/#/user,服务器实际收到的请求都是 http://example.com/,只需返回单页应用的入口 HTML 即可。

  • history 模式
    必须配置服务器。因为当用户直接访问 http://example.com/user 时,浏览器会向服务器发送该路径的请求,若服务器未配置对应路由,会返回 404 错误。
    解决方法:服务器需将所有路由请求重定向到单页应用的入口 HTML(如 index.html)。
    示例配置(Nginx):

    location / {try_files $uri $uri/ /index.html;
    }
    
4. 功能限制不同
  • hash 模式

    • # 后面的内容无法作为 HTTP 请求的一部分,因此不利于 SEO(搜索引擎可能忽略 # 后的内容)。
    • 不能使用 history.go(n) 等方法精确控制历史记录(但日常使用影响不大)。
  • history 模式

    • 支持 history.state 存储额外数据,可在路由跳转时传递更多信息。
    • 可以使用 popstate 事件监听历史记录变化,实现更灵活的导航控制。
    • URL 更利于 SEO 和分享(无 # 符号,更符合常规 URL 规范)。
5、如何选择?
  • 若项目需要兼容旧浏览器(如 IE9 及以下),或不想配置服务器,选择 hash 模式
  • 若追求更美观的 URL、更好的 SEO 支持,且能配置服务器,选择 history 模式(推荐现代项目使用)。
6、模式切换方式

在创建路由实例时指定模式:

import { createRouter, createWebHashHistory, createWebHistory } from 'vue-router'// hash 模式
const router = createRouter({history: createWebHashHistory(), // 使用 hash 模式routes: [...]
})// history 模式
const router = createRouter({history: createWebHistory(), // 使用 history 模式routes: [...]
})

总结:两种模式核心功能一致,但 history 模式在 URL 美观性和功能扩展性上更优,而 hash 模式在兼容性和部署便捷性上更有优势。

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

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

相关文章

从现场到云端的“通用语”:Kepware 在工业互联中的角色、使用方法与本土厂商(以胡工科技为例)的差异与优势

从现场到云端的“通用语”&#xff1a;Kepware 在工业互联中的角色、使用方法与本土厂商&#xff08;以胡工科技为例&#xff09;的差异与优势 文章目录从现场到云端的“通用语”&#xff1a;Kepware 在工业互联中的角色、使用方法与本土厂商&#xff08;以胡工科技为例&#x…

深入理解Prompt构建与工程技巧:API高效实践指南

深入理解Prompt构建与工程技巧&#xff1a;API高效实践指南 引言 Prompt&#xff08;提示&#xff09;工程是推动大模型能力极限的关键手段。合理的Prompt不仅能显著提升模型输出的相关性与准确性&#xff0c;在实际落地的API接口开发中同样起到举足轻重的作用。本文将系统介…

C++之多态(从0到1的突破)

世间百态&#xff0c;每个人都扮演着不同的角色&#xff0c;都进行着不同的行为。C更是如此&#xff0c;C中也会出现有着不同行为的多种形态的出现&#xff0c;那就让我们一起进入C的多态世界吧&#xff01;&#xff01;&#xff01; 一. 多态的概念 多态&#xff0c;顾名思义&…

路由器NAT的类型测定

目前所使用的NAT基本都是NAPT&#xff0c;即多端口的NAT技术&#xff0c;因此本文主要是设计了两种测定路由器NAPT类型的实验。 实验环境 设备 主机A&#xff1a;Windows主机B&#xff1a;Windows路由器 软件 ncWiresharkSocketTools 在局域网内部完成所有测试&#xff0c;完全…

ROS 2系统Callback Group概念笔记

核心概念 Callback Group&#xff08;回调组&#xff09;是一个管理一个或多个回调函数执行规则的容器。它决定了这些回调函数是如何被节点&#xff08;Node&#xff09;的 executor 调度的&#xff0c;特别是当多个回调函数同时就绪时&#xff0c;它们之间是并行执行还是必须串…

Qt——主窗口 mainWindow

主窗口 mainWindow 前面学习的所有代码&#xff0c;都是基于QWidget控件&#xff0c;其更多的是作为别的窗口的部分 现在来学习QMainWindow&#xff0c;即主窗口&#xff0c;其包含以下属性 Window Title&#xff1a;标题栏Menu Bar&#xff1a;菜单栏Tool Bar Area&#xff1a…

无训练神经网络影响下的智能制造

摘要 未训练神经网络&#xff08;Untrained Neural Networks, UNNs&#xff09;作为近年来人工智能领域的新兴范式&#xff0c;正在逐步改变智能制造的发展路径。不同于传统深度学习依赖大规模标注数据与高性能计算资源的模式&#xff0c;UNNs 借助网络结构自身的归纳偏置与初…

微服务自动注册到ShenYu网关配置详解

一、配置逐行详解 shenyu:register:registerType: http # 注册中心类型:使用 HTTP 协议进行注册serverLists: ${shenyu-register-serverLists} # ShenYu Admin 的地址列表props:username: ${shenyu-register-props-username} # 注册认证用户名password: ${shenyu-regi…

时序数据库IoTDB的列式存储引擎

在大数据时代&#xff0c;工业物联网&#xff08;IIoT&#xff09;场景正以前所未有的速度生成着海量的时间序列数据。这些数据通常由成千上万的传感器&#xff08;如温度、压力、转速传感器&#xff09;持续不断采集产生&#xff0c;它们具备鲜明的特点&#xff1a;数据时间属…

JavaScript手录18-ajax:异步请求与项目上线部署

前言&#xff1a;软件开发流程 AJAX&#xff1a;前端与后端的数据交互 前后端协作基础 Web应用的核心是“数据交互”&#xff0c;前端负责展示与交互&#xff0c;后端负责处理逻辑与数据存储&#xff0c;二者通过网络请求协作。 &#xff08;1&#xff09;项目开发流程与岗…

HTB 赛季7靶场 - Enviroment

最近所幸得点小闲&#xff0c;补个档嘞&#xff01;~nmap扫描 nmap -F -A 10.10.11.67dirsearch扫描发现login接口 http://environment.htb/login构造如下payload&#xff0c;让程序报错&#xff0c;其原理在于缺失了rember后会导致报错&#xff0c;从而告诉我们一个新的参数ke…

源码编译部署 LAMP 架构详细步骤说明

源码编译部署 LAMP 架构详细步骤说明 一、环境准备 1. 关闭防火墙和SELinux [roothrz ~]# systemctl stop firewalld [roothrz ~]# systemctl disable firewalld [roothrz ~]# setenforce 02. 配置YUM网络源 [roothrz ~]# curl -o /etc/yum.repos.d/CentOS-Base.repo https://m…

机器学习----PCA降维

一、PCA是什么&#xff1f;主成分分析&#xff08;Principal Component Analysis&#xff0c;PCA&#xff09;是机器学习中最常用的降维技术之一&#xff0c;它通过线性变换将高维数据投影到低维空间&#xff0c;同时保留数据的最重要特征。PCA由卡尔皮尔逊于1901年发明&#x…

ReactNative开发实战——React Native开发环境配置指南

一、开发前准备 1. macOS平台基础工具安装 brew install node18 brew install watchman brew install cocoapods2. 代理配置 npm config set proxy http://127.0.0.1:7890 npm config set https-proxy http://127.0.0.1:7890# 新增扩展建议&#xff08;可选配置&#xff09; ec…

差速转向机器人研发:创新驱动的未来移动技术探索

在科技日新月异的今天&#xff0c;机器人技术作为智能制造与自动化领域的核心驱动力&#xff0c;正以前所未有的速度发展。其中&#xff0c;差速转向机器人以其独特的运动机制和广泛的应用前景&#xff0c;成为了科研与工业界关注的焦点。本文旨在探讨差速转向机器人研发进展&a…

Wireshark捕获电脑与路由器通信数据,绘制波形观察

一、准备工作 电脑发出数据的波形图绘制在我的另一篇博客有详细介绍&#xff1a; 根据Wireshark捕获数据包时间和长度绘制电脑发射信号波形-CSDN博客 路由器发送给电脑数据的波形图绘制也在我的另一篇博客有详细介绍&#xff1a; 根据Wireshark捕获数据包时间和长度绘制路由…

汽车ECU实现数据安全存储(机密性保护)的一种方案

一、 综述在车辆ECU中总是有一些密钥或重要数据需进行机密性保护&#xff0c;但因产品选型、成本等考虑&#xff0c;导致一些ECU的芯片不支持硬件安全模块&#xff08;例如HSM、TEE等&#xff09;。此时&#xff0c;为保障数据的机密性&#xff0c;可考虑通过软件实现数据的安全…

AI 效应: GPT-6,“用户真正想要的是记忆”

每周跟踪AI热点新闻动向和震撼发展 想要探索生成式人工智能的前沿进展吗&#xff1f;订阅我们的简报&#xff0c;深入解析最新的技术突破、实际应用案例和未来的趋势。与全球数同行一同&#xff0c;从行业内部的深度分析和实用指南中受益。不要错过这个机会&#xff0c;成为AI领…

云计算学习100天-第25天

部署LNMP环境安装软件#在前一天已经安装nginx的基础上安装MariaDB&#xff0c;php和php-fpm yum -y install mariadb mariadb-server mariadb-devel php php-mysqlnd php-fpm #mariadb&#xff08;数据库客户端软件&#xff09;、mariadb-server&#xff08;数据库服务器软件&…

细化的 Spring Boot 和 Spring Framework 版本对应关系

注:本文由ai辅助,个人整理,有问题可留言 Spring Boot 3.x 系列 (基于 Spring Framework 6.x) Spring Boot 版本 对应的 Spring Framework 版本 Java 支持版本 3.1.5 (最新) 6.0.15 Java 17+ 3.1.4 6.0.14 Java 17+ 3.1.3 6.0.12 Java 17+ 3.1.2 6.0.11 Java 17+ 3.1.1 6.0.…