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

深入理解 Vue Router:构建可靠的前端路由系统

目录

  • 01-什么是前端路由以及路由两种模式实现原理
  • 02-路由的基本搭建与嵌套路由模式
  • 03-动态路由模式与编程式路由模式
  • 04-命名路由与命名视图与路由元信息
  • 05-路由传递参数的多种方式及应用场景
  • 06-详解route对象与router对象
  • 07-路由守卫详解及应用场景

01-什么是前端路由以及路由两种模式实现原理

  • 前端路由是指在单页应用(SPA,Single Page Application)中,通过客户端的路由机制实现页面切换和导航的方式。它将不同的 URL 映射到相应的组件或页面,并通过页面切换而无需重新加载整个页面。
  • 前端路由的特点包括:
    1. 基于 URL:前端路由使用 URL 来标识不同的页面或视图状态。每个页面或视图状态都有一个对应的 URL,用户可以通过修改 URL 来导航到不同的页面或视图。

    2. 单页应用:前端路由通常用于单页应用。在单页应用中,所有的页面内容都加载一次,之后的页面切换只是替换了相应的组件或视图内容,而不需要重新加载整个页面,提供了更流畅的用户体验。

    3. 前端控制:前端路由是在客户端控制的。它通过 JavaScript 来监听 URL 的变化,并根据 URL 的不同来渲染相应的组件或视图内容,实现页面切换和导航。

    4. 动态加载:前端路由可以动态加载所需的组件或视图。当用户访问一个新页面时,路由系统会根据配置动态地加载对应的组件代码,从而避免了一次性加载所有页面内容带来的性能消耗。

    5. 无需刷新:前端路由通过动态地替换组件或视图内容来实现页面切换,从而避免了整个页面的刷新。这不仅提高了页面加载速度,还能保持用户在切换页面时的当前状态,提供更好的用户体验。

02-路由的基本搭建与嵌套路由模式

  • vue路由的搭建

    npm install vue-router
    
    • 配置路由信息,并且与Vue进行结合,让路由插件生效。在/src/router/index.js创建配置文件:
      在这里插入图片描述
  • vue路由的应用
    在这里插入图片描述

  • 嵌套路由模式
    在这里插入图片描述

03-动态路由模式与编程式路由模式

  • 动态路由模式
    • 所谓的动态路由其实就是不同的URL可以对应同一个页面,这种动态路由一般URL还是有规律可循的,所以非常适合做类似于详情页的功能。
      在这里插入图片描述
      在这里插入图片描述
  • 编程式路由
    • 在JavaScript中通过逻辑的方式进行路由跳转 在这里插入图片描述

04-命名路由与命名视图与路由元信息

  • 命名路由

    • 在路由跳转中,除了path 之外,你还可以为任何路由提供name的形式进行路由跳转:
      • 没有硬编码的 URL
      • params 的自动编码/解码
      • 防止你在 url 中出现打字错误
      • 绕过路径排序(如显示一个)
        在这里插入图片描述
  • 命名视图

    • 有时候想同时 (同级) 展示多个视图,而不是嵌套展示,这个时候就非常适合使用命名视图。
      在这里插入图片描述
  • 路由元信息

    • 有时,你可能希望将任意信息附加到路由上,如过渡名称、谁可以访问路由等。这些事情可以通过接收属性对象的meta属性来实现。
      在这里插入图片描述

05-路由传递参数的多种方式及应用场景

  • 路由的传递参数主要有以下三种方式:

    • query方式(显示) -> $route.query
    • params方式(显示) -> $route.params
    • params方式(隐式) -> $route.params
  • 两种显示传递数据的差异点主要为:

    • query是携带辅助信息
    • params是界面的差异化
      在这里插入图片描述
    • 注意:隐式发送过来的数据,只是临时性获取的,一旦刷新页面,隐藏的数据就会消失。

06-详解route对象与router对象

  • route对象用来获取路由信息,是针对获取操作的,主要是操作当前路由的。

    • route对象具体功能如下:(主要是一些路由信息)

      • fullPath
      • hash
      • href
      • matched
      • meta
      • name
      • params
      • path
      • query
  • router对象用来调用路由方法,是针对设置操作的,主要是操作整个路由系统对应的功能.

    • router对象具体功能如下:(主要是一些方法)

      • addRoute
      • afterEach
      • back
      • beforeEach
      • beforeResolve
      • currentRoute
      • forward
      • getRoutes
      • go
      • hasRoute
      • push
      • removeRoute

07-路由守卫详解及应用场景

  • vue-router 提供的导航守卫主要用来通过跳转或取消的方式守卫导航
    • 进入到指定路由前做一个拦截,看一下我们是否具备权限,如果有权限就直接进入,如果没权限就跳转到其他页面。
  • 路由守卫分类
    • 全局环境的守卫beforEach
      在这里插入图片描述

    • 路由独享的守卫beforeEnter
      在这里插入图片描述

    • 组件内的守卫beforeRouteEnter
      在这里插入图片描述

  • 完整的导航解析流程
    1. 导航被触发。
    2. 在失活的组件里调用 beforeRouteLeave 守卫。
    3. 调用全局的 beforeEach 守卫。
    4. 在重用的组件里调用 beforeRouteUpdate 守卫(2.2+)。
    5. 在路由配置里调用beforeEnter
    6. 解析异步路由组件。
    7. 在被激活的组件里调用 beforeRouteEnter。
    8. 调用全局的 beforeResolve 守卫(2.5+)。
    9. 导航被确认。
    10. 调用全局的 afterEach 钩子。
    11. 触发 DOM 更新。
    12. 调用 beforeRouteEnter 守卫中传给 next 的回调函数,创建好的组件实例会作为回调函数的参数传入
http://www.lryc.cn/news/142090.html

相关文章:

  • Mysql B+数索引结构
  • 在window上配置NASM
  • 用QT实现MVP模式
  • (2023)Linux安装pytorch并使用pycharm远程编译运行
  • poi带表头多sheet导出
  • RedisDesktopManager(redis客户端,可输入用户名密码)
  • 【Adobe After Effects】关于ae点击空格不会播放反而回退一帧的解决方案
  • Linux网络编程:多路I/O转接服务器(select poll epoll)
  • Mybatis系列原理剖析之项目实战:自定义持久层框架
  • 阿里云 Serverless 应用引擎 2.0,正式公测!
  • 西北大学计算机考研844高分经验分享
  • 【java并发编程的艺术读书笔记】volatile关键字介绍、与synchronized的区别
  • LinkedList的顶级理解
  • 再学http-为什么文件上传要转成Base64?
  • 使用oracleVM搭建虚拟机
  • 深入探讨C存储类和存储期——Storage Duration
  • 医学图像融合的深度学习方法综述
  • 【Qt学习】04:QDialog
  • 如何更好的进行异常处理
  • 若依微服务版部署到IDEA
  • Elasticsearch 入门安装
  • 【80天学习完《深入理解计算机系统》】第十一天 3.5 过程(函数调用)
  • LinuxUbuntu安装VMware tools Segmentation fault (core dumped)怎么解决
  • 002微信小程序云开发API数据库-迁移状态查询/更新索引
  • 十几款拿来就能用的炫酷表白代码
  • 证券低延时环境设置并进行性能测试
  • 百度工程师浅析解码策略
  • windows下实现查看软件请求ip地址的方法
  • 【JAVA】String 类
  • LoRA继任者ReLoRA登场,通过叠加多个低秩更新矩阵实现更高效大模型训练效果