百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

Vue实战053:el-menu组件实现路由导航菜单详解

zhezhongyun 2025-05-09 22:48 2 浏览

在WEB开发中,导航菜单作为网站的基础组成部分,它是整个网站的结构的体现,可以引导用户快速选择查找内容。所以一个好的导航可以是必不可少的,它可以减少用户跳出率、降低用户时间成本、增加网站回头率,提高网站流量、提升网站权重、增强用户体验。

在Element中提供了NavMenu组件可以为网站提供导航功能的菜单,这里我们主要来研究下侧边折叠导航栏菜单的功能实现,Element提供了一个简单的示例,属性我们可以参考Element官网的NavMenu 导航菜单说明:

简单介绍下该示例,这里el-menu定义了当前的导航菜单及属性,el-submenu定义了子菜单栏,el-menu-item-group定义了菜单分组,el-menu-item为具体的菜单项,组件从上到下分别是:el-menu, el-submenu, el-menu-item-group, el-menu-item。在这里有个slot="title"的属性,这代表什么意思呢?我们可以来看下el-submenu组件是怎么定义的。

在组件中我们可以看到有<slot name="title"></slot>元素,这是一个具名的< slot >(指定了slot="title"),可以用来定义额外的插槽,这样父组件引用子组件时,含有属性slot="title"标签内的所有内容将替代子组件的< slot >标签及它的内容。 如果< slot >没有使用name特性时它将作为默认slot出现,父组件没有使用slot特性的元素与内容都将出现,如果没定义默认slot则父组件中没有使用slot特性的元素与内容不会显示。

有了以上知识我们就可以开始构建属于自己的导航了,官方给我们展示的是固定的导航菜单,但在实际的项目开发中导航菜单大部分都是通过路由动态配置的,所以这里我们需要小小的改变下,在NavMenu中index 是菜单的唯一标识符,当启用 vue-router 的模式时导航以 index 作为 path 进行路由跳转。

在路由中有些路由是不需要在菜单中显示的,比如注册、登录、找回、401、404、500等页面,所以我们在定义路由的时候可以添加一个属性来过滤掉不需要显示的路由。

先来实现一个简单的一级菜单,屏蔽掉含有hidden属性的路由,然后通过routes方法我们先对路由进行判断,先获取路由中的路由信息并将路由赋给subroutes,然后我们对路由个数进行判断,如果只有一条路由或者子路由为空时就返回真,拿到没有子路由的对象我们就可以通过el-menu-item标签展示出来了。

因为还有子路由的菜单需要使用到el-submenu标签,它封装了展开/收起箭头。所以我们先从路由中提取出没有子路由的对象,直接通过el-menu-item标签来实现即可。而没有子菜单的菜单我们希望点击时能只能跳转路由,所以我们可以在el-menu-item外包裹个router-link标签,通过to属性来指向对应的路由。

接着我们继续将含有子路由的菜单内容提取出来,el-submenu是个菜单项没有实际内容,所以我们不需要对该项进行跳转。直接使用template标签实现即可。在显示图标和标题时我们最好先对路由进行过滤,如果存在则显示,不然容易报错的。这时候我们只是获取了一个带有展开/收起箭头的菜单项,里面没有实际内容的,要想在子菜单中显示内容我们就要在el-submenu通过el-menu-item标签实现。

这里问题就来了,在子菜单中也有没有下级菜单的,所以我们在这里就需要再次对路由进行层级判断并重复之前的操作,而且我们也不知道路由会有几层不可能不限的去嵌套,这里我们用到了vue的组件递归功能。就是组件可以在自己的模板中调用自身,递归必须定义name属性(调用组件名和组件属性name名需一致才能实现递归)而且一定要有结束条件,否则组件就会被循环引用最终出现“max stack size exceeded”的错误。

注意事项:

1,刷新定位当前路由,需要在el-menu标签中定义:default-active="$route.path",这样当你刷新路由时就会自动定位但当前的路由位置。

2,el-submenu和el-menu-item标签中的index属性定义,需要解析下路由将要跳转的路由赋给index。

更多Vue实战技巧可以参考我的专栏:Vue实战系列

相关推荐

最新全国高校名单一键查!报志愿就用它了

7月9日,教育部公布最新全国高等学校名单。截至2020年6月30日,全国高等学校共计3005所,其中:普通高等学校2740所,含本科院校1258所、高职(专科)院校1482所;成人高等学校265所。高...

(十三)C#WinFrom自定义控件系列-导航菜单

前提入行已经7,8年了,一直想做一套漂亮点的自定义控件,于是就有了本系列文章。本系列文章将讲解各种控件的开发及思路,欢迎各位批评指正。此系列控件开发教程将全部在原生控件基础上进行重绘开发,目标的扁平化...

录取结果早知道!安徽高考录取结果这样查询……

据安徽省教育招生考试院消息,从8月9晚23:00起,将正式开通2020年高考录取结果查询,考生可陆续查询到录取结果。8月8日起,安徽省2020年普通高校招生录取工作已全面展开,每位考生的录取须经过投档...

CS架构开发之-WPF平台权限菜单(关于wps权限的设定有哪些是可行的)

CS架构开发之-WPF平台权限菜单;在之前的基础上,使用EFCode添加本地SQLite数据库;使软件能够保存数据到本地,以及后期其他业务需要和服务器进行数据上传和下载。后期在改造升级为全完仓储...

解锁C#新技能:巧用钩子实现Winform窗体智能关闭

一、引言在Winform应用程序的开发中,我们常常会遇到一些有趣且实用的需求。比如,当用户长时间没有操作键盘和鼠标时,自动关闭Winform窗体,以此来节省系统资源或者实现特定的业务逻辑。实...

DevExpress WinForms——支持HTML &amp; CSS模板全新的DirectX表单

DevExpressWinForms控件附带了许多标准的System.Windows.Forms.Form对象对应的对象,在v22.1版本发布新的表单选项之前,让我们一起看看当前所有可用的表单选项。...

如何打造优质 Web 表单(web表单简单代码)

来人人都是产品经理【起点学院】,BAT实战派产品总监手把手系统带你学产品、学运营。这篇文章算是笔者交的一份读书笔记,与CRM系统打交道了这么久,表单天天见。如果表单有感情的话,我猜它应该都不想再看...

Excel常用技能分享与探讨(5-宏与VBA简介 VBA之用户窗体-避坑指南)

书接上文,之前是VBA用户窗体中常用控件的详细解析,涵盖核心属性、关键事件、典型应用场景及代码示例,下面是窗体使用中遇到的一些问题点汇总。五、避坑指南:五大常见问题5.1、控件操作相关问题1:未初始化...

Excel中窗体的新建与设置;窗体控件新增及代码的录入。

由于前期分享的好多作品中都运用到了窗体。有很多朋友都私信小编,如何更改窗体里面的文字以及设置窗体背景图片。为此小编将根据自己的经验总结,在这里给大家做一个详细的讲解。1、新建窗体:打开Excel表格后...

Excel常用技能分享与探讨(5-宏与VBA简介 VBA之用户窗体-复选框)

书接上文,以下是VBA用户窗体中常用控件的详细解析,涵盖核心属性、关键事件、典型应用场景及代码示例,助您精准掌握每个控件的使用方法。三、核心控件精讲3.6.复选框(CheckBox)3.6.1、复选...

VBA代码对单选框条件控制方法及循环的使用方法

VBA代码对单选框条件的控制方法在上一篇文章的基础上,在创建好选项组之后,我们来看一下在单击事件后,它所返回的值是什么样的,首先右键单击选项组框,在弹出的菜单中选择事件生成器:弹出代码窗口后,在单击事...

实现窗体录入数据的代码(excel窗体录入数据实例)

【分享成果,随喜正能量】学会坚强,这世上,真正在乎你的人并不多,相反,倒是有很多人都在等着看你的笑话。就算遇到天大的麻烦,也不要自暴自弃。你不勇敢,没人替你坚强。《VBA之Excel应用》是非常经典的...

从交互的角度讲讲弹窗(中)(确认弹窗设计)

编辑导读:弹窗是吸引注意力的一种方式,不管是PC端还是移动端都广泛使用。本文作者从交互设计的角度,对弹窗进行分析,与你分享。上期我们小聊了一下弹窗的定义与使用的常见场景,本期我们来聊点实际的:弹窗的内...

Excel批量导入图片,还能一键将图片固定到单元格!这是什么操作

私信回复关键词【福利】,获取丰富办公资源!助你高效办公早下班!大家好,我是懂点Excel的小E~初入「江湖」,还请大家多多关照!今天我们来学学Excel图片的6个小技巧,满满都是干货,记得...

老板让我把图片放到Excel表格中,批量插入效率高

私信回复关键词【福利】,获取丰富办公资源!助你高效办公早下班!大家好,我是懂点Excel的小E~初入「江湖」,还请大家多多关照!今天我们来学学Excel图片的6个小技巧,满满都是干货,记得...