手把手教你使用Vue2.0实现动态路由展示

news2024/11/24 13:28:08

文章目录

    • VUE2相关组件版本
    • 原始菜单数据
      • 数据库数据
      • 树形数据
    • 前端项目
      • 配置静态路由
      • 配置路由守卫
      • 左侧路由回显代码

使用Vue2实现动态路由展示

思路:

  1. 后端返回树形数据
  2. 根据数据渲染左侧菜单
  3. 根据数据组装路由数据

注意:本文主要目的讲解是一种思路,如果有更好的实现方式,欢迎评论留言。

VUE2相关组件版本

这里需要注意下有版本关系,如果不对应会有不同的问题。

我使用的版本如下:

"axios": "^1.6.0",
"element-ui": "^2.15.14",
"node-sass": "^4.14.1",
"sass-loader": "^13.3.2",
"vue": "^2.6.14",
"vue-router": "^3.5.1",
"vuex": "^3.6.2"

原始菜单数据

数据库数据

在这里插入图片描述

树形数据

{
	"code": 0,
	"msg": "操作成功",
	"data": [{
		"id": 1,
		"delFlag": 0,
		"createTime": null,
		"updateTime": null,
		"pid": 0,
		"title": "系统管理",
		"component": null,
		"sort": null,
		"icon": "el-icon-setting",
		"path": "system",
		"children": [{
			"id": 2,
			"delFlag": 0,
			"createTime": null,
			"updateTime": null,
			"pid": 1,
			"title": "用户管理",
			"component": "/system/User",
			"sort": null,
			"icon": "el-icon-user-solid\r\n",
			"path": "user",
			"children": null
		}, {
			"id": 3,
			"delFlag": 0,
			"createTime": null,
			"updateTime": null,
			"pid": 1,
			"title": "菜单管理",
			"component": "/system/Module",
			"sort": null,
			"icon": "el-icon-s-platform\r\n",
			"path": "module",
			"children": null
		}]
	}]
}

前端项目

在/router/index.js文件中

// 控制无限点击面包屑报错
const originalPush = VueRouter.prototype.push;
VueRouter.prototype.push = function push(location) {
    return originalPush.call(this, location).catch((err) => err);
};
Vue.use(VueRouter);

配置静态路由

当页面进入后,默认进入登录页面。

//静态路由
const routes = [// 初始化重定向
    {path: "/", component: Login},
    {path: "/login", component: Login},
];
// 创建路由实例 导入配置项
const router = new VueRouter({
    routes, mode: "history",
});

配置路由守卫

当用户登录成功后,请求菜单数据。开始组装路由

let isToken = true
router.beforeEach(async (to, from, next) => {
    let token = getToken();
    if (token) {
        //获取路由并加载
        if (isToken) {
            //从后台获取到路由数据
            let menuData = await reqListLeftSysMenu({});
            let result = assertRouter(menuData.data);
            setLeftMenu(JSON.stringify(menuData.data))
            let test = [{
                path: "/home",
                component: Layout,
                children: result
            }];
            router.addRoutes(test);
            isToken = false;
            next({
                ...to, // next({ ...to })的目的,是保证路由添加完了再进入页面 (可以理解为重进一次)
                replace: true, // 重进一次, 不保留重复历史
            })
        }
    }
    next();
});
function assertRouter(data) {
    //一级菜单处理
    let result = [];
    data.forEach(item => {
        item.children.forEach(item1 => {
            let childObj = {
                path: "/" + item.path + "/" + item1.path,
                component: () => import(`@/views${item1.component}`),
            };
            result.push(childObj);
        })
    })
    return result;
}

关键代码是使用router.addRoutes来动态添加路由信息。

这里我使用了setLeftMenu来进行缓存原始菜单数据,用于左侧渲染菜单。

在这里插入图片描述

左侧路由回显代码

<el-menu style="height:500px"
                 default-active="2"
                 class="el-menu-vertical-demo"
                 background-color="#545c64"
                 text-color="#fff"
                 active-text-color="#ffd04b"
                 @select="handleSelect"
        >
            <el-submenu v-for="item in menuDataList" :index="item.path">
                <template slot="title">
                    <i :class="item.icon"></i>
                    <span>{{ item.title }}</span>
                </template>
                <el-menu-item v-for="child in item.children" :index="child.path">
                    <i :class="child.icon"></i>
                    {{ child.title }}
                </el-menu-item>
            </el-submenu>
        </el-menu>
<script>
import {getLeftMenu} from "@/utils/SessionStorage";

export default {
    name: "Left",
    created() {
        this.menuDataList = JSON.parse(getLeftMenu());
    },
    data() {
        return {
            menuDataList: []
        }
    },
    methods: {
        handleSelect(key, keyPath) {
            let jumpPath = "";
            for (let i = 0; i < keyPath.length; i++) {
                jumpPath += "/" + keyPath[i];
            }
            this.$router.push(jumpPath);
        },
    }
}
</script>

当点击左侧菜单后,进行跳转路由。

在这里插入图片描述

实现上方效果,则表示动态路由添加成功。

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

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

相关文章

47GB水经微图从入门到精通视频教程

本视频教程共47GB&#xff0c;为了方便大家观看&#xff0c;同时录制了横版视频教程和竖版视频教程。 本视频教程的内容主要包括快速入门、地图标注、影像下载、高程下载和矢量下载几部分。 本文将列出所有视频教程所有内容。 快速入门&#xff08;23.1GB&#xff09; 如何…

串口实用解说

我们学习单片机&#xff0c;首先接触的可能是点灯&#xff08;GPIO&#xff09;&#xff0c;再次就是串口&#xff08;UART&#xff09;。 串口是常用的一种通信接口&#xff0c;也是学嵌入式必备掌握的一项知识&#xff0c;但我发现有很多小伙伴只知道用串口输出或者打印一些数…

《windows核心编程》第4章 进程

一、进程基本概念 1、进程&#xff1a;一个进程就是一个正在运行的程序&#xff0c;一个程序可以产生多个进程。进程包含下面两个东西 ● 进程内核对象&#xff1a;一个内核对象被系统用来管理某个进程&#xff0c;内核对象就是代表这个进程。这个内核对象中&#xff0c;还包…

CTS分析思路

目录 原理简介&#xff1a; Cts测试原理&#xff1a; CTS报告与日志目录 CTS报告目录如下​编辑 log查看 举例 原理简介&#xff1a; Cts环境搭建和测试方法&#xff0c;大家可以自行查询网上资料。 Cts测试原理&#xff1a; 输入命令后&#xff0c;会安装一系列的测试…

短视频账号矩阵系统/剪辑/矩阵/无人直播/文案引流爆款

一、 短视频账号矩阵源码开发包含哪几方面&#xff1f; 1. 界面设计&#xff1a;需要根据用户需求&#xff0c;设计出优美简洁的UI界面&#xff0c;使用户可以方便快捷地管理自己的短视频账号。 2. 数据存储&#xff1a;需要将用户的账号信息、数据统计等信息存储在数据库中&a…

pytorch dropout 置零 + 补偿性放缩

一句话概括&#xff1a;&#xff08;训练过程中&#xff09;Dropout 操作 随机置零 非置零元素进行后补偿性放缩。以保证dropout前后数据scale不变。 详细解释(来自chatgpt): 在 PyTorch 中&#xff0c;dropout 的操作不仅仅是将某些元素置零。为了确保期望输出在训练和测试…

WoShop跨境电商商城源码(多语言多货币多商户进出口电商平台)

一、跨境电商商城系统源码包括以下几个部分 前端框架&#xff1a;uni-app,vue 后端框架&#xff1a;ThinkPHP5.wokerman 支付系统&#xff1a;PayPal、USDT等主流支付平台 语言包&#xff1a;跨境电商支持15种语言&#xff0c;后续会增加 前端&#xff1a;包含APP端、小程序端、…

无需数据搬迁,10倍性能提升!携程的统一分析之旅

作者&#xff1a;携程技术中心大数据总监 许鹏 携程自 2022 年起引入了 StarRocks&#xff0c;目前已经成为了集团内部的主要技术栈&#xff0c;应用到酒店、机票、商旅、度假、市场、火车票等多个关键业务线。目前&#xff0c;携程内部已经拥有超过 10 个 StarRocks 集群&…

c语言函数宏的几种封装方式

c语言函数宏的几种封装方式 在c语言开发中&#xff0c;除了使用函数封装代码之外&#xff0c;也经常使用宏来封装一些重要或简洁的代码。 宏在c开发有三种&#xff1a;预定义宏&#xff0c;不带参宏&#xff0c;和带参数宏&#xff0c;通常&#xff0c;带参数宏也叫函数宏&am…

HR应用人才测评来提升人才价值

对于企业而言&#xff0c;产出价值是最重要的&#xff0c;但企业拥有人才&#xff0c;才能产出更多的价值&#xff0c;做HR这么久发现很多企业&#xff0c;都欠缺人才管理的测评技术&#xff0c;导致很多人才被埋没或者浪费&#xff0c;这也说明一个很大的问题&#xff0c;一定…

Github 自动化部署到GitHub Pages

1.准备工作 新建仓库 新建项目 配置 vite.config.ts base: ./,部署应用包时的基本URL&#xff0c;例&#xff1a;vue-cli 5.x 配置 publicPath 推送到远程仓库 2.配置 GitHub Token 点击 Settings -> Actions -> General 找到 Workflow permissions&#xff0c;选中第…

sqlserver涉及到三种排序后生成的数字

with temp as (select 1 标识,2023-01-01 日期,a 项目union all select 1,2023-01-01,a union all select 2,2023-01-01,a union all select 2,2023-01-01,b union all select 3,2023-01-01,a union all select 3,2023-01-01,b union all select 3,2023-01-01,c union all …

耳朵小戴什么耳机合适,2023年适合小耳道的蓝牙无线耳机分享

你们是否曾为了追求音乐的同时&#xff0c;担心自己的听力健康呢&#xff1f;尤其是耳朵小的群体&#xff0c;佩戴入耳式时间一长&#xff0c;就会感觉耳道存在一定的疼痛感&#xff0c;不过别担心&#xff0c;现在有了一种完美的解决方案——骨传导耳机&#xff01;这种炫酷的…

解决Windows Server 2012 由于没有远程桌面授权服务器可以提供需求可证

刚开始提示 之后就登录不了 &#xff08;如下图提示&#xff09; 由于windows server 2012 R2 安装了 远程桌面角色&#xff0c;但是这个角色是120天免费的&#xff0c;需要购买授权的。解决方法是取消/删除这个角色&#xff0c;就可以恢复正常的远程 一直下一步 远程桌面服…

2023年阿里云双11活动云服务器可选实例规格、配置及活动价格分享

阿里云服务器2023年双11活动价格是多少&#xff1f;轻量应用服务器2核2G3M带宽轻量服务器87元1年、2核4G4M带宽165元1年&#xff1b;云服务器经济型e实例2核2G3M配置99元1年&#xff1b;计算型c7实例2核4G1M配置864.79元1年&#xff1b;通用型g7实例2核8G1M配置1089.91元1年&am…

Linux C语言进阶-D9字符指针与字符串

初始化字符指针&#xff1a;把内存中字符串的首地址赋予指针&#xff0c;并不是把该字符串复制到指针中。 char str[] "Hello World"; char *p str; 在C编程中&#xff0c;当一个字符指针指向一个字符串常量时&#xff0c;不能修改指针指向的对象的值 char * p &…

【PC】第26赛季第2轮更新公告

正式服维护日期 ※ 下列时间可能会根据维护情况而发生变化。 11月8日上午8:00 – 下午4:30 地图轮换 ※ 地图轮换将于北京时间每周三上午10点进行。 ※ 在随机选择地图的区域中&#xff0c;各地图将按大型地图25%、小型地图12.5%的概率随机匹配。 测试服 普通比赛&#xf…

Capybara库如何批量下载新浪图片

按照要求写一个使用Capybara库的下载程序。该程序使用Ruby下载新浪新闻的图片&#xff0c;并使用爬虫IP服务器duoip的8000端口进行下载。 require capybara require mechanize# 创建一个爬虫IP服务器实例 proxy Mechanize.new爬虫IP主机: duoip,爬虫IP端口: 8000# 访问新浪新闻…

黑马最新「SpringBoot3+Vue3」全套教程上线,练手很香

转眼2023年仅剩2个月&#xff0c;大家的“卷”也进入了白热化阶段&#xff0c;毕竟10月随份子的钱还没还完&#xff0c;双11又付了一大笔尾款&#xff0c;还要准备回家过年的钱……为了更卷&#xff08;赚更多钱&#xff09;&#xff0c;又又又有程序员来找播妞要新教程了。 “…

全球地表动态水体产品(数据集V2.0)(2000-2020年/8天/250米)

摘要 全球地表动态水体产品(8天/250米)GSWED(Global Surface Water Extent Dataset)由中国科学院空天信息创新研究院湿地与环境遥感研究团队制作而成。本套数据集是基于MODIS数据构建了一套全球地表水体NDVI阈值时空参数集,在此基础上使用遥感大数据云平台进行研发的,使用G…