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

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

ztj100 2025-06-29 22:04 4 浏览 0 评论

在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实战系列

相关推荐

使用Python编写Ping监测程序(python 测验)

Ping是一种常用的网络诊断工具,它可以测试两台计算机之间的连通性;如果您需要监测某个IP地址的连通情况,可以使用Python编写一个Ping监测程序;本文将介绍如何使用Python编写Ping监测程...

批量ping!有了这个小工具,python再也香不了一点

号主:老杨丨11年资深网络工程师,更多网工提升干货,请关注公众号:网络工程师俱乐部下午好,我的网工朋友。在咱们网工的日常工作中,经常需要检测多个IP地址的连通性。不知道你是否也有这样的经历:对着电脑屏...

python之ping主机(python获取ping结果)

#coding=utf-8frompythonpingimportpingforiinrange(100,255):ip='192.168.1.'+...

网站安全提速秘籍!Nginx配置HTTPS+反向代理实战指南

太好了,你直接问到重点场景了:Nginx+HTTPS+反向代理,这个组合是现代Web架构中最常见的一种部署方式。咱们就从理论原理→实操配置→常见问题排查→高级玩法一层层剖开说,...

Vue开发中使用iframe(vue 使用iframe)

内容:iframe全屏显示...

Vue3项目实践-第五篇(改造登录页-Axios模拟请求数据)

本文将介绍以下内容:项目中的public目录和访问静态资源文件的方法使用json文件代替http模拟请求使用Axios直接访问json文件改造登录页,配合Axios进行登录请求,并...

Vue基础四——Vue-router配置子路由

我们上节课初步了解Vue-router的初步知识,也学会了基本的跳转,那我们这节课学习一下子菜单的路由方式,也叫子路由。子路由的情况一般用在一个页面有他的基础模版,然后它下面的页面都隶属于这个模版,只...

Vue3.0权限管理实现流程【实践】(vue权限管理系统教程)

作者:lxcan转发链接:https://segmentfault.com/a/1190000022431839一、整体思路...

swiper在vue中正确的使用方法(vue中如何使用swiper)

swiper是网页中非常强大的一款轮播插件,说是轮播插件都不恰当,因为它能做的事情太多了,swiper在vue下也是能用的,需要依赖专门的vue-swiper插件,因为vue是没有操作dom的逻辑的,...

Vue怎么实现权限管理?控制到按钮级别的权限怎么做?

在Vue项目中实现权限管理,尤其是控制到按钮级别的权限控制,通常包括以下几个方面:一、权限管理的层级划分...

【Vue3】保姆级毫无废话的进阶到实战教程 - 01

作为一个React、Vue双修选手,在Vue3逐渐稳定下来之后,是时候摸摸Vue3了。Vue3的变化不可谓不大,所以,本系列主要通过对Vue3中的一些BigChanges做...

Vue3开发极简入门(13):编程式导航路由

前面几节文章,写的都是配置路由。但是在实际项目中,下面这种路由导航的写法才是最常用的:比如登录页面,服务端校验成功后,跳转至系统功能页面;通过浏览器输入URL直接进入系统功能页面后,读取本地存储的To...

vue路由同页面重定向(vue路由重定向到外部url)

在Vue中,可以使用路由的重定向功能来实现同页面的重定向。首先,在路由配置文件(通常是`router/index.js`)中,定义一个新的路由,用于重定向到同一个页面。例如,我们可以定义一个名为`Re...

那个 Vue 的路由,路由是干什么用的?

在Vue里,路由就像“页面导航的指挥官”,专门负责管理页面(组件)的切换和显示逻辑。简单来说,它能让单页应用(SPA)像多页应用一样实现“不同URL对应不同页面”的效果,但整个过程不会刷新网页。一、路...

Vue3项目投屏功能开发!(vue投票功能)

最近接了个大屏项目,产品想在不同的显示器上展示大屏项目不同的页面,做出来的效果图大概长这样...

取消回复欢迎 发表评论: