【vue-router】vue-router如何实现动态路由

news2024/11/29 9:34:42

在这里插入图片描述

✨✨ 欢迎大家来到景天科技苑✨✨

🎈🎈 养成好习惯,先赞后看哦~🎈🎈

🏆 作者简介:景天科技苑
🏆《头衔》:大厂架构师,华为云开发者社区专家博主,阿里云开发者社区专家博主,CSDN全栈领域优质创作者,掘金优秀博主,51CTO博客专家等。
🏆《博客》:Python全栈,Golang开发,云原生开发,前后端框架,PyQt5和Tkinter桌面开发,小程序开发,人工智能,js逆向,App逆向,网络系统安全,数据分析,Django,fastapi,flask等框架,云原生K8S集群搭建与管理,linux,shell脚本等实操经验,网站搭建,数据库等分享。

所属的专栏:前端零基础,实战进阶教学
景天的主页:景天科技苑

文章目录

  • Vue-Router动态路由
    • 一、动态路由的基本概念与作用
    • 二、动态路由的基本用法
    • 三、动态路由的详细用法与案例
      • 1. 动态路由与异步组件
      • 2. 动态添加路由
        • 使用`addRoute`方法
        • 使用Vuex保存动态路由
      • 3. 动态路由与命名视图
      • 4. 动态路由与路由元信息
      • 5. 动态路由与嵌套路由

Vue-Router动态路由

在构建基于Vue.js的单页面应用(SPA)时,Vue Router是一个不可或缺的工具。它提供了声明式的路由功能,使开发者能够轻松地管理和控制应用内的导航逻辑。动态路由是Vue Router中的一项重要特性,它允许我们根据运行时的数据来动态地匹配路由。这对于需要根据用户输入或后端响应来调整应用行为的场景尤其有用。本文将详细介绍动态路由的概念、作用及其在Vue Router中的具体实现,并通过一系列实际案例来展示如何有效地使用这项功能。

一、动态路由的基本概念与作用

动态路由是指在路由定义中包含动态部分的路由,这些部分通常使用占位符(如:id)来表示,实际的值会在导航发生时根据具体情况填充进去。动态路由的一个主要用途是在不知道具体值的情况下,为一组相似的资源创建共享的路由路径。

动态路由具有以下优势:

  1. 灵活性:允许在运行时根据数据变化来确定路由路径。
  2. 可维护性:减少重复路由定义的数量,使得路由管理更为简洁。
  3. 扩展性:容易为新资源或类别添加路由,无需大幅改动现有的路由配置。

二、动态路由的基本用法

假设我们需要为每一个用户创建一个个人资料页面,我们可以定义一个动态路由来实现这一点。

import Vue from 'vue';
import VueRouter from 'vue-router';
import UserProfile from './components/UserProfile.vue';

Vue.use(VueRouter);

const routes = [
  // 动态路由定义
  { path: '/user/:id', component: UserProfile }
];

const router = new VueRouter({
  routes // (缩写) 相当于 routes: routes
});

new Vue({
  router,
  render: h => h(App)
}).$mount('#app');

在UserProfile组件中,我们可以通过$route.params访问传递过来的动态参数:

<template>
  <div>
    <h1>User Profile</h1>
    <p>UserID: {{ $route.params.id }}</p>
  </div>
</template>

<script>
export default {
  created() {
    console.log('User ID:', this.$route.params.id);
  }
};
</script>

动态路由不仅仅限于单一参数,还可以定义多个参数来匹配更复杂的路径结构。

const routes = [
  { path: '/user/:id/post/:postId', component: PostDetail }
];

// PostDetail 组件
export default {
  created() {
    console.log('User ID:', this.$route.params.id);
    console.log('Post ID:', this.$route.params.postId);
  }
};

三、动态路由的详细用法与案例

1. 动态路由与异步组件

在大型应用中,为了避免首屏加载时间过长,我们可能会使用异步组件来延迟加载某些路由对应的组件。

const routes = [
  { path: '/user/:id', component: () => import('./components/UserProfile.vue') }
];

const router = new VueRouter({
  routes
});

new Vue({
  router,
  render: h => h(App)
}).$mount('#app');

2. 动态添加路由

Vue Router 3.5.0版本开始引入了addRoute方法,它允许我们在应用程序运行时动态添加路由。通过这种方式,我们可以在用户登录后或其他特定操作后动态地添加新的路由。

使用addRoute方法
import Vue from 'vue';
import VueRouter from 'vue-router';
import Home from './components/Home.vue';
import About from './components/About.vue';
import DynamicComponent from './components/DynamicComponent.vue';

Vue.use(VueRouter);

const router = new VueRouter({
  routes: [
    // 静态路由
    { path: '/', component: Home },
    { path: '/about', component: About },
  ],
});

// 动态添加路由的函数
function addDynamicRoute() {
  router.addRoute({ path: '/dynamic', component: DynamicComponent });
}

// 在某个操作中调用动态添加路由
addDynamicRoute();

调用addDynamicRoute函数后,新的路由将被添加到路由表中,并且可以通过/dynamic路径访问。

需要注意的是,在Vue Router 3.0版本中,我们可以使用router.addRoutes方法动态添加路由。但这种方法在3.5.0版本后被addRoute方法取代。

使用Vuex保存动态路由

在一些复杂的应用场景中,我们可能需要在不同组件或模块间共享动态路由信息。这时,我们可以使用Vuex或其他状态管理工具来保存和管理动态路由。

import Vue from 'vue';
import Vuex from 'vuex';
import VueRouter from 'vue-router';
import Home from './components/Home.vue';
import About from './components/About.vue';
import DynamicComponent from './components/DynamicComponent.vue';

Vue.use(Vuex);
Vue.use(VueRouter);

const store = new Vuex.Store({
  state: {
    dynamicRoutes: [],
  },
  mutations: {
    addRoute(state, route) {
      state.dynamicRoutes.push(route);
    },
  },
});

const router = new VueRouter({
  routes: [
    // 静态路由
    { path: '/', component: Home },
    { path: '/about', component: About },
  ],
});

// 动态添加路由的函数
function addDynamicRoute(route) {
  store.commit('addRoute', route);
  router.addRoute(route);
}

// 在某个操作中调用动态添加路由
addDynamicRoute({ path: '/dynamic', component: DynamicComponent });

在上面的示例中,我们使用Vuex store来保存动态路由,并在需要时通过store.commit方法更新store中的路由信息。然后,我们调用router.addRoute方法将新的路由添加到Vue Router实例中。

3. 动态路由与命名视图

在复杂的SPA中,我们可能会有多个路由组件需要同时渲染在同一页面的不同区域。这时候可以使用命名视图来实现。

const routes = [
  {
    path: '/user/:id',
    component: {
      template: `
        <div>
          <header>
            <Header />
          </header>
          <main>
            <router-view name="main"></router-view>
            <router-view name="sidebar"></router-view>
          </main>
        </div>
      `,
      components: { Header },
    },
    children: [
      { path: '', component: UserProfile, name: 'UserProfile' },
      { path: 'settings', component: Settings, name: 'UserSettings' }
    ]
  }
];

// UserProfile 组件
export default {
  name: 'UserProfile',
  template: `
    <div>
      <router-view name="sidebar"></router-view>
      <section>
        <UserProfileMain />
      </section>
    </div>
  `,
  components: { UserProfileMain }
};

// Settings 组件
export default {
  name: 'Settings',
  template: `
    <div>
      <router-view name="sidebar"></router-view>
      <section>
        <UserProfileSettings />
      </section>
    </div>
  `,
  components: { UserProfileSettings }
};

4. 动态路由与路由元信息

有时候我们需要在路由对象上附加上一些元信息,例如页面标题、是否需要认证等,这些信息可以在组件中通过$route.meta访问。

const routes = [
  { path: '/user/:id', component: UserProfile, meta: { title: 'User Profile' } }
];

// UserProfile 组件
export default {
  created() {
    document.title = this.$route.meta.title;
  }
};

5. 动态路由与嵌套路由

对于复杂的SPA,考虑使用嵌套路由来更好地组织路由结构。

const routes = [
  {
    path: '/user/:id',
    component: User,
    children: [
      // 匹配 /user/:id
      { path: '', component: UserHome },
      // 匹配 /user/:id/profile
      { path: 'profile', component: UserProfile },
      // 匹配 /user/:id/posts
      { path: 'posts', component: UserPosts }
    ]
  }
];

要注意,以/开头的嵌套路径会被当作根路径。这让你充分地使用嵌套组件而无须设置嵌套的路径。

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Web前端技术浅谈CooKieAG网址漏洞与XSS攻防策略

随着互联网技术的飞速发展,Web前端开发已经成为构建网站和应用程序的重要环节。然而,Web前端开发中存在许多安全问题,这些问题不仅会影响用户体验,还可能给企业和个人带来严重的经济损失。但是web前端安全方面技术包含的东西较多&#xff0c;我们这里着重聊一聊关于XSS 的危害与…

关于VNC连接时自动断联的问题

在服务器端打开VNC Server的选项设置对话框&#xff0c;点左边的“Expert”&#xff08;专家&#xff09;&#xff0c;然后找到“IdleTimeout”&#xff0c;将数值设置为0&#xff0c;点OK关闭对话框。搞定。 注意,服务端有两个vnc服务,这俩都要设置ide timeout为0才行 附件是v…

51c自动驾驶~合集35

我自己的原文哦~ https://blog.51cto.com/whaosoft/12206500 #纯视觉方案的智驾在大雾天还能用吗&#xff1f; 碰上大雾天气&#xff0c;纯视觉方案是如何识别车辆和障碍物的呢&#xff1f; 如果真的是纯纯的&#xff0c;特头铁的那种纯视觉方案的话。 可以简单粗暴的理解为…

计算分数的浮点数值

计算分数的浮点数值 C语言代码C 代码Java代码Python代码 &#x1f490;The Begin&#x1f490;点点关注&#xff0c;收藏不迷路&#x1f490; 两个整数a和b分别作为分子和分母&#xff0c;既分数 a/b &#xff0c;求它的浮点数值&#xff08;双精度浮点数&#xff0c;保留小数点…

戴尔电脑安装centos7系统遇到的问题

1&#xff0c;找不到启动盘&#xff08;Operation System Loader signature found in SecureBoot exclusion database(‘dbx’).All bootable devices failed secure Boot Verification&#xff09; 关闭 Secure Boot&#xff08;推荐&#xff09;&#xff1a; 进入 BIOS/UEFI…

简单获取json预览

data: JSON 数据。 collapsedNodeLength: 对象或数组的长度超过此阈值时会折叠 deep: json路径深度超过此值时会折叠 showLineNumber: 显示左侧行号 showIcon: 显示图标。 virtual: 使用虚拟滚动 height: 使用虚拟滚动时列表的高度 itemHeight: 使用虚拟滚动时节点的高…

ChatGPT/AI辅助网络安全运营之-数据解压缩

在网络安全的世界中&#xff0c;经常会遇到各种压缩的数据&#xff0c;比如zip压缩&#xff0c;比如bzip2压缩&#xff0c;gzip压缩&#xff0c;xz压缩&#xff0c;7z压缩等。网络安全运营中需要对这些不同的压缩数据进行解压缩&#xff0c;解读其本意&#xff0c;本文将探索一…

Cookie概念和API

Cookie概念 Cookie在HTTP中它表示服务器送给客户端浏览器的小甜点。其实Cookie就是一个键和一个值构成的&#xff0c;随着服务器端的响应发送给客户端浏览器。然后客户端浏览器会把Cookie保存起来&#xff0c;当下一次再访问服务器时把Cookie再发送给服务器。 Cookie是由服务器…

qt音频实战

一、Qt音频基础知识 1、QT multimedia 2、QMediaPlayer类&#xff1a;媒体播放器&#xff0c;主要用于播放歌曲、网络收音机等功能。 3、QMediaPlaylist类&#xff1a;专用于播放媒体内容的列表。 二、界面设计 三、代码 #include "mainwindow.h" #include "…

GDPU Android移动应用 数据存储

又是学到了数据持久化。 登录界面 题外话&#xff1a;有无动画大佬带带呀&#xff0c;前端移动端可免( •̀ .̫ •́ )&#xff0c;合作可私信哦。 1.用户登陆和“记住我”功能 该内容拥有两个Activity活动视图&#xff1a; &#xff08;1&#xff09;LoginActivity&#x…

Java算法OJ(11)双指针练习

目录 1.前言 2.正文 2.1存在重复数字 2.1.1题目 2.1.2解法一代码 解析&#xff1a; 2.1.3解法二代码 解析&#xff1a; 2.2存在重复数字plus 2.2.1题目 2.2.2代码 2.2.3解析 3.小结 1.前言 哈喽大家好吖&#xff0c;今天来给大家分享双指针算法的相关练习&…

天锐绿盾加密软件与Ping32联合打造企业级安全保护系统,确保敏感数据防泄密与加密管理

随着信息技术的飞速发展&#xff0c;企业在日常经营过程中产生和处理的大量敏感数据&#xff0c;面临着越来越复杂的安全威胁。尤其是在金融、医疗、法律等领域&#xff0c;数据泄漏不仅会造成企业巨大的经济损失&#xff0c;还可能破坏企业的信誉和客户信任。因此&#xff0c;…

Git上传本地项目到远程仓库(gitee/github)

目录 序言一、创建git本地版本库二、连接远程仓库&#xff08;以gitee为例&#xff09;三、将项目提交到git&#xff08;本地&#xff09;版本库1.由工作区添加到暂存区2.由暂存区添加到版本库 四、将代码由本地仓库上传到 gitee远程仓库1.获取远程库与本地同步2.把当前分支 ma…

C7.【C++ Cont】范围for的使用和auto关键字

目录 1.知识回顾 2.范围for 格式 使用 运行结果 运行过程 范围for的本意 作用 注意 3.底层分析范围for的执行过程 反汇编代码 分析 4.auto关键字 格式 基本用法 在范围for中使用auto 1.知识回顾 for循环的使用参见25.【C语言】循环结构之for文章 2.范围for C…

【仓颉学习02】编译后运行报错:“由于找不到libcanjie-runtime.dll,无法继续执行代码。重新安装程序可能会解决此问题。”

敲了段《仓颉语言实践》&#xff08;张磊著&#xff09;书上的代码&#xff0c;如下&#xff1a; package test //coding:utf-8struct Employee{var name:Stringprivate var realSalary:Float64public Employee(name:String,realSalary:Float64){this.namenamethis.realSalary…

AI智算-正式上架GPU资源监控概览 Grafana Dashboard

下载链接 https://grafana.com/grafana/dashboards/22424-ai-gpu-20241127/

LINUX2.4.x网络安全框架

在分析LINUX2.4.x网络安全的实现之前先简介一下它里面包括的几个重要概念&#xff1a;netfilter、iptables、match、target、nf_sockopt_ops、网络安全功能点的实现。详解会在后面的分析中讲到。 首先是netfilter&#xff0c;它定义了协议栈中的检查点和在检查点上引用的数据结…

【博主推荐】C# Winform 拼图小游戏源码详解(附源码)

文章目录 前言摘要1.设计来源拼图小游戏讲解1.1 拼图主界面设计1.2 一般难度拼图效果1.3 普通难度拼图效果1.4 困难难度拼图效果1.5 地域难度拼图效果1.6 内置五种拼图效果 2.效果和源码2.1 动态效果2.2 源代码 源码下载结束语 前言 在数字浪潮汹涌澎湃的时代&#xff0c;程序开…

pytorch错误: 找不到指定的模块 Error loading “torch_python.dll“ or one of its dependencies

省流&#xff1a;python(3.12.7) 和 pytorch(2.4.0)版本不配套 问题 起因是看到了这本书《Build a Large Language Model (From Scratch) 》&#xff0c;是2024年9月新出的&#xff0c; 作者 Sebastian Raschka&#xff0c;想要按照作者给出的步骤来手搓一个大语言模型&#…

渗透测试学习笔记(一)渗透测试方法论

一.渗透测试方法论 渗透测试方法论是制定实施信息安全审计方案时&#xff0c;需要遵循的规则&#xff0c;惯例和过程。人们在评估网络&#xff0c;应用&#xff0c;系统或者三者组合的安全状态时&#xff0c;不断摸索各种实务的理念和成熟的做法&#xff0c;并总结了一套理论-…