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

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

ruisui883个月前 (02-03)技术分析10

在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组件实现路由导航菜单详解” 的相关文章

Ubuntu 24.10发行版登场:Linux 6.11内核、GNOME 47桌面环境

IT之家 10 月 11 日消息,Canonical 昨日发布新闻稿,正式推出代号为 Oracular Oriole 的 Ubuntu 24.10 发行版。新版在内核方面升级到最新 6.11 版本,并采用 GNOME 47 桌面环境。Ubuntu 24.10 发行版调整了内核策略,开始选择最新的上游...

react hooks自定义组件居然能这样做

前言  这里写一下如何封装可复用组件。首先技术栈 react hooks + props-type + jsx封装纯函数组件。类组件和typeScript在这不做讨论,大家别白跑一趟。接下来会说一下封装可复用组件的思路,比如一个新手应该怎么去封装,都需要有哪些东西。  然后说一些复杂组件需要的功能,...

用IDEA开发如何用Git快速拉取指定分支代码?

1,准备空的文件夹,git init2,关联远程仓库,git remote add origin gitlab地址3,拉取远程分支代码,git pull origin 远程分支名再用IDEA打开项目即可...

Java教程:gitlab-使用入门

1 导读本教程主要讲解了GitLab在项目的环境搭建和基本的使用,可以帮助大家在企业中能够自主搭建GitLab服务,并且可以GitLab中的组、权限、项目自主操作GitLab简介GitLab环境搭建GitLab基本使用(组、权限、用户、项目)2 GitLab简介GitLab是整个DevOps生命周期...

高效使用 Vim 编辑器的 10 个技巧

在 Reverb,我们使用 MacVim 来标准化开发环境,使配对更容易,并提高效率。当我开始使用 Reverb 时,我以前从未使用过 Vim。我花了几个星期才开始感到舒服,但如果没有这样的提示,可能需要几个月的时间。这里有十个技巧可以帮助你在学习使用 Vim 时提高效率。1. 通过提高按键重复率来...

你感动了吗?佳能超规格镜头 RF 24-105mm F2.8深度测评

如果要你选一支用作多题材创作的挂机镜头,那我相信很多人会选择24-105mm这个焦段的镜头。作为一支可以实现从广角到长焦的变焦镜头,24-105mm有着丰富的焦段选择。只是基于镜头体积以及光学结构上的限制,此前的24-105mm镜头只能恒定在F4的光圈。而佳能打破了这一限制,将实用焦段和恒定光圈完美...