当前位置:首页 > 技术分析 > 正文内容

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

ruisui884个月前 (02-03)技术分析18

在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 >(指定了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实战系列

扫描二维码推送至手机访问。

版权声明:本文由ruisui88发布,如需转载请注明出处。

本文链接:http://www.ruisui88.com/post/816.html

分享给朋友:

“Vue实战053:el-menu组件实现路由导航菜单详解” 的相关文章

壹啦罐罐 Android 手机里的 Xposed 都装了啥

这是少数派推出的系列专题,叫做「我的手机里都装了啥」。这个系列将邀请到不同的玩家,从他们各自的角度介绍手机中最爱的或是日常使用最频繁的 App。文章将以「每周一篇」的频率更新,内容范围会包括 iOS、Android 在内的各种平台和 App。本期继续歪楼,由少数派撰稿作者@壹啦罐罐介绍他正在使用的...

我的VIM配置

写一篇关于VIM配置的文章,记录下自己的VIM配置,力求简洁实用。VIM的配置保存在文件~/.vimrc中(Windows下是C:\Users\yourname \_vimrc)。VIM除了自身可配置项外,还可插件扩展。VIM的插件一般用vundle或vim-plug来管理,但我力求简单,不打算装太...

别让“跑焦”毁所有!仅需这一项设置,即可显著改善镜头对焦精度

我常常会收到一些摄影爱好者的私信,也一直在努力的帮助大家解决更多摄影中常见问题。在我收到的所有问题中。有一个问题是最麻烦的,那就是“为什么我的图像看起来模糊?”。这个问题几乎每个人都遇到过,究其原因可以说是多种多样相对复杂。起初我一直认为是对焦问题所导致,也就有了我之前所写的“后按对焦”以及“对焦模...

TDesign企业级开源设计系统越发成熟稳定,支持 Vue3 / 小程序

TDesing 发展越来越好了,出了好几套组件库,很成熟稳定了,新项目完全可以考虑使用。早在2021年,腾讯的 TDesing 刚发布不久,我就写了一篇简短的文章来介绍,当时主要关注的是 TDesign 的 Vue 组件库和用来搭建 admin 后台系统的实用性。虽然当时看起来不错,但还处于测试版,...

html5迁移到微信小程序的 方法 亲测可用

切图网习惯于在做小程序之前先做成html5+vuejs的形式,因为html5切图是我们比较熟悉的方式,而且有专业的工具 以及浏览器调试也会更加的方便 灵活,效率高,而且html5的方式可以方便预览看效果,方便调整,当html5页面做好确认没问题以后 再转成小程序或者官方出品wepy的方式,这个时候就...

同步电机和异步电机竟然有这么大区别,看完就理解了

同步电机和异步电机的主要区别是:同步电机能与其定子磁场旋转达到同步转速,异步电机转速达不到定子磁场的同步转速。电机大致分成三种,同步机,异步机(以上两种多与电网相连),还有个直流电机。下面的内容是一个过渡,只作为对电机(同步机、异步机)原理性的知识进行形象的讲解(懂电机的可跳过)。同步机和异步机,这...