vue element 生成无线级左侧菜单的实现代码


Posted in Javascript onAugust 21, 2019

首先来总结element ui 官方文档的左侧菜单结构,带有el-submenu为子级节点,el-menu-item表示没有下级。当然,菜单不能写死,因为菜单也许不止两级,所以我们需要递归来实现。根据当前节点是否有下级去判断,如果有下级,则继续调用子级,直到没有下级为止,下面我贴上左侧菜单所有的代码:

请求数据格式

[
   {
    name: "首页",
    id: -1,
    icon: "el-icon-picture-outline-round",
    url: "/index",
    children: []
   },
   {
    name: "按钮",
    id: 20,
    icon: "el-icon-message-solid",
    url: "/button",
    children: []
   },
   {
    name: "测试1",
    id: 1,
    icon: "el-icon-s-claim",
    url: "",
    children: [
     {
      id: 4,
      parentid: 1,
      name: "测试1-1",
      icon: "el-icon-chat-dot-round",
      url: "",
      children: [
       {
        id: 8,
        parentid: 1,
        name: "测试1-1-1",
        icon: "el-icon-cloudy",
        url: "/test",
        children: []
       },
       {
        id: 9,
        parentid: 1,
        name: "测试1-1-2",
        icon: "el-icon-files",
        url: "/test1",
        children: []
       }
      ]
     },
     {
      id: 5,
      parentid: 1,
      name: "测试1-2",
      icon: "el-icon-shopping-cart-1",
      url: "/test3",
      children: []
     }
    ]
   },
   {
    name: "测试2",
    id: 2,
    icon: "el-icon-menu",
    url: "",
    children: [
     {
      id: 6,
      parentid: 2,
      name: "测试2-1",
      icon: "el-icon-folder-checked",
      url: "",
      children: []
     },
     {
      id: 7,
      parentid: 2,
      name: "测试2-2",
      icon: "el-icon-folder-remove",
      url: "",
      children: []
     }
    ]
   },
   {
    name: "测试3",
    id: 3,
    icon: "el-icon-monitor",
    url: "",
    children: []
   }
  ]

menu.vue

<template>
 <div class="menu">
  <div class="logo-con">
   <div class="title" v-show="!collapse">
    <span class="title__sider-title is-active">{{logo}}</span>
   </div>
   <div class="title" v-show="collapse">
    <span class="title__sider-title el-tag--mini">LG</span>
   </div>
  </div>
  <el-menu
   :background-color="backgroundColor"
   :text-color="textColor"
   :default-active="$route.meta.pageId"
   :collapse="collapse"
  >
   <template v-for="item in list">
    <router-link :to="item.url" :key="item.id" v-if="item.children.length===0">
     <el-menu-item :index="item.id.toString()">
      <i :class="item.icon"></i>
      <span slot="title">{{item.name}}</span>
     </el-menu-item>
    </router-link>
    <subMenu v-else :data="item" :key="item.id"></subMenu>
   </template>
  </el-menu>
 </div>
</template>

<script>
import subMenu from "./subMenu";
export default {
 name: "menuList",
 components: {
  subMenu
 },
 data() {
  return {
   collapse: false, //是否折叠
   list: [], //当行菜单数据源
   backgroundColor: "#304156", //导航菜单背景颜色
   textColor: "#BFCBD9", //导航菜单文字颜色
   logo: "LOGO" //logo
  };
 }
};
</script>

<style lang="scss" scoped>
.el-menu {
 border-right: none;
 a {
  text-decoration: none;
 }
}
.logo-con {
 height: 64px;
 padding: 10px;

 .title {
  position: relative;
  text-align: center;
  font-size: 20px;
  height: 64px;
  line-height: 64px;

  span {
   padding: 0 5px 0 0;
   color: #409eff;
   font-size: 20px;
  }
 }
}
</style>

submenu.vue

这里有个知识点functional,不懂自行百度,文档地址: https://cn.vuejs.org/v2/guide/render-function.html#search-query-sidebar

5 <!--
 * @Description: 
 * @Author: PengYH
 * @Date: 2019-08-06
 -->
<template functional>
 <el-submenu :index="props.data.id.toString()">
  <template slot="title">
   <i :class="props.data.icon"></i>
   <span>{{props.data.name}}</span>
  </template>
  <template v-for="item in props.data.children">
   <router-link :to="item.url" :key="item.id" v-if="item.children.length===0">
    <el-menu-item class="subitem" :index="item.id.toString()">
     <i :class="item.icon"></i>
     <span slot="title">{{item.name}}</span>
    </el-menu-item>
   </router-link>
   <sub-menu v-else :data="item" :key="item.id"></sub-menu>
  </template>
 </el-submenu>
</template>
<script>
export default {
 name: "submenu",
 props: {
  data: [Array, Object]
 }
};
</script>
<style lang="scss" scoped>
.el-submenu {
 .el-menu-item {
  padding: 0;
 }
}
</style>

效果图

vue element 生成无线级左侧菜单的实现代码

总结

以上所述是小编给大家介绍的vue element 生成无线级左侧菜单的实现代码,希望对大家有所帮助,如果大家有任何疑问欢迎给我留言,小编会及时会及时回复大家的!

Javascript 相关文章推荐
javascript开发随笔二 动态加载js和文件
Nov 25 Javascript
无闪烁更新网页内容JS实现
Dec 19 Javascript
JavaScript闭包函数访问外部变量的方法
Aug 27 Javascript
使用JavaScript+canvas实现图片裁剪
Jan 30 Javascript
js从数组中删除指定值(不是指定位置)的元素实现代码
Sep 13 Javascript
JavaScript 链式结构序列化详解
Sep 30 Javascript
深入理解Angularjs向指令传递数据双向绑定机制
Dec 31 Javascript
从零开始搭建webpack+react开发环境的详细步骤
May 18 Javascript
angular4强制刷新视图的方法
Oct 09 Javascript
vue子传父关于.sync与$emit的实现
Nov 05 Javascript
vue更改数组中的值实例代码详解
Feb 07 Javascript
OpenLayer学习之自定义测量控件
Sep 28 Javascript
微信小程序仿今日头条导航栏滚动解析
Aug 20 #Javascript
Vue中axios的封装(报错、鉴权、跳转、拦截、提示)
Aug 20 #Javascript
Vue formData实现图片上传
Aug 20 #Javascript
Angular8 Http拦截器简单使用教程
Aug 20 #Javascript
vue实现axios图片上传功能
Aug 20 #Javascript
扫微信小程序码实现网站登陆实现解析
Aug 20 #Javascript
vue+element-ui+axios实现图片上传
Aug 20 #Javascript
You might like
PHP中限制IP段访问、禁止IP提交表单的代码
2011/04/23 PHP
thinkphp3.0 模板中函数的使用
2012/11/13 PHP
详解在PHP的Yii框架中使用行为Behaviors的方法
2016/03/18 PHP
joomla实现注册用户添加新字段的方法
2016/05/05 PHP
yii框架结合charjs实现统计30天数据的方法
2020/04/04 PHP
javascript实现简单的全选和反选功能
2016/01/05 Javascript
Bootstrap3 内联单选和多选框
2016/12/29 Javascript
微信小程序实现实时圆形进度条的方法示例
2017/02/24 Javascript
微信小程序开发之toast等弹框提示使用教程
2017/06/08 Javascript
vue实现商城上货组件简易版
2017/11/27 Javascript
vue-cli配置环境变量的方法
2018/07/09 Javascript
Vue中控制v-for循环次数的实现方法
2018/09/26 Javascript
[01:21]DOTA2新纪元-7.0新版本即将开启!
2016/12/11 DOTA
Python和GO语言实现的消息摘要算法示例
2015/03/10 Python
深入理解python中的atexit模块
2017/03/07 Python
Python在图片中添加文字的两种方法
2017/04/29 Python
python中WSGI是什么,Python应用WSGI详解
2017/11/24 Python
python数据抓取分析的示例代码(python + mongodb)
2017/12/25 Python
Python3.6连接Oracle数据库的方法详解
2018/05/18 Python
Django和Flask框架优缺点对比
2019/10/24 Python
python 控制台单行刷新,多行刷新实例
2020/02/19 Python
python实现PCA降维的示例详解
2020/02/24 Python
python GUI库图形界面开发之PyQt5单行文本框控件QLineEdit详细使用方法与实例
2020/02/27 Python
HTML5+css3:3D旋转木马效果相册
2017/01/03 HTML / CSS
英国著名的药妆网站:Escentual
2016/07/29 全球购物
俄罗斯运动鞋商店:Sneakerhead
2018/05/10 全球购物
安全生产责任书
2014/03/12 职场文书
初中作文评语大全
2014/04/23 职场文书
和谐拯救危机观后感
2015/06/15 职场文书
教师节座谈会主持词
2015/07/03 职场文书
上班旷工检讨书
2015/08/15 职场文书
七年级写作指导之游记作文
2019/10/07 职场文书
python 批量压缩图片的脚本
2021/06/02 Python
Go语言基础map用法及示例详解
2021/11/17 Golang
JavaScript实现优先级队列
2021/12/06 Javascript
JavaScript事件的委托(代理)的用法示例详解
2022/02/18 Javascript