vue Element左侧无限级菜单实现


Posted in Javascript onJune 10, 2020

最近项目中,要用到element-ui的无限级分类菜单,根据角色生成不同的递归数据,查阅了网上很多资料,发现很多都不太完整并且没有很多的延伸性。

梳理递归数据

我们一般拿到后台的数据是:1.扁平化数据格式2.递归式数据格式

let arr = [
{
  name:小七,
  id:1
},
{
  name:小八,
  id:2
},
{
  name: 小九,
  id:3
}
]

我们从后台拿到的是这种扁平化处理数据,那我们实现递归菜单的话需要什么数据格式呢,需要格式如下:

let menuItems = [
{
  name:小七,
  id:1,
  children:[
    {
      name: '啥也不是',
      pid:2
    }
  ]
},
{
  name:小八,
  id:2,
  children:[
    {
      name:'随便写哦',
      pid:3,
      children:[
        {
          name: '再次深入',
          pid: 4,
          children:[
            {
              name: '撒打算',
              pid:666
            }
          ]
        }
      ]
    }  
  ]
},
{
  name: 小九,
  id:3
}
]

我们就需要类似于以上的这种数据格式:
扁平化数据转换递归数据,下面贴出我的数据处理方法:
注:应为在网上看到的许多的递归处理方法都不一样,有的文章写于很早很多方法都比较复杂或者代码比较多余

computed: {
  treeData() {
   let cloneData = JSON.parse(JSON.stringify(this.tableData)); // 对源数据深度克隆
   return cloneData.filter(father => {
    let branchArr = cloneData.filter(child => father.id == child.pid); //返回每一项的子级数组
    branchArr.length > 0 ? (father.children = branchArr) : ""; //如果存在子级,则给父级添加一个children属性,并赋值
    return father.pid == 0; //返回第一层
   });
  }
 },

其中this.tableData就是后台给到我的扁平化数据,这里将其替换就可以

当时处理此功能时没有考虑到子级或者父级有可能值位udfriend 所以没有做判断,如果想完善此递归数据处理的可以完善一下。

数据处理就要开始写代码了!

这里用到了vue-ement-ui的左侧菜单

老规矩,程序员交流用代码

index.vue

<el-menu
    background-color="#304156"
    text-color="#fff"
    active-text-color="#409eff"
    :collapse="isActive"
    :collapse-transition="false"
    :unique-opened="true"
    :router="true"
    :default-active="activePath"
   >
    <menu-tree :menuData="treeData" @saveNavStart="saveNavStart"></menu-tree>
   </el-menu>
   
   这里的激活样式用的是缓存的办法
   // 保存链接的激活状态
  saveNavStart(activePath) {
   window.sessionStorage.setItem("activePath", activePath);
   this.activePath = activePath;
  },
  created() {
    this.activePath = window.sessionStorage.getItem("activePath");
  }

menuTree.vue组件

实现左侧无限级菜单最重要的就是 组件自身调用自身
废话不多说,上代码:

<template>
 <div>
  <label v-for="menu in menuData" :key="menu.id">
   <el-submenu :index="String(menu.id)" v-if="menu.children">
    <template slot="title">
     <i class="el-icon-edit"></i>
     <span>{{menu.menu_name}}</span>
    </template>
    <label>
     <menutree :menuData="menu.children"></menutree>
    </label>
   </el-submenu>
   <el-menu-item :index="menu.path" @click="saveNavStart(menu.path)" v-else>
    <i class="el-icon-edit"></i>
    <span>{{menu.menu_name}}</span>
   </el-menu-item>
  </label>
 </div>
</template>

methods:{
  saveNavStart(activePath) {
    this.$emit('saveNavStart',activePath)
  }
  }
}

到此就实现了左侧菜单的无限级了,应为现在给公司写的项目都是权限功能,路由方面呢大家可以随便写,公司项目做了权限:左侧菜单,按钮限制,菜单限制,接口限制目前是四种。
本人只是一个小白,分享在项目中遇到的问题,在百度没有找到好的方法,踩坑分享出来。

到此这篇关于vue Element左侧无限级菜单实现的文章就介绍到这了,更多相关vue Element左侧无限级菜单内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Javascript 相关文章推荐
学习JavaScript设计模式(多态)
Nov 25 Javascript
javascript中eval解析JSON字符串
Feb 27 Javascript
requireJS使用指南
Apr 27 Javascript
深入理解jQuery之防止冒泡事件
May 24 Javascript
JQuery点击行tr实现checkBox选中的简单实例
May 26 Javascript
jQuery与JavaScript节点创建方法的对比
Nov 18 Javascript
利用vue-router实现二级菜单内容转换
Nov 30 Javascript
vue-cli 脚手架基于Nightwatch的端到端测试环境的过程
Sep 30 Javascript
ajaxfileupload.js实现上传文件功能
Apr 19 Javascript
webpack-mvc 传统多页面组件化开发详解
May 07 Javascript
Javascript数组方法reduce的妙用之处分享
Jun 10 Javascript
JavaScript 函数用法详解【函数定义、参数、绑定、作用域、闭包等】
May 12 Javascript
详解用js代码触发dom事件的实现方案
Jun 10 #Javascript
Vue中key的作用示例代码详解
Jun 10 #Javascript
使用JavaScript获取扫码枪扫描得到的条形码的思路代码详解
Jun 10 #Javascript
js 获取扫码枪输入数据的方法
Jun 10 #Javascript
使用Vue Composition API写出清晰、可扩展的表单实现
Jun 10 #Javascript
使用 UniApp 实现小程序的微信登录功能
Jun 09 #Javascript
详解vue高级特性
Jun 09 #Javascript
You might like
山进SANGEAN ATS-909X电路分析
2021/03/02 无线电
php基础知识:类与对象(4) 范围解析操作符(::)
2006/12/13 PHP
支持数组的ADDSLASHES的php函数
2010/02/16 PHP
CodeIgniter上传图片成功的全部过程分享
2013/08/12 PHP
php libevent 功能与使用方法详解
2020/03/04 PHP
一个对于js this关键字的问题
2007/01/09 Javascript
一个简单的JavaScript 日期计算算法
2009/09/11 Javascript
jQuery探测位置的提示弹窗(toolTip box)详细解析
2013/11/14 Javascript
NodeJS url验证(url-valid)的使用方法
2013/11/18 NodeJs
jquery实现Slide Out Navigation滑出式菜单效果代码
2015/09/07 Javascript
逻辑表达式中与或非的用法详解
2016/06/06 Javascript
通过BootStrap实现轮播图的实际应用
2016/09/26 Javascript
angular 动态组件类型详解(四种组件类型)
2017/02/22 Javascript
提高Web性能的前端优化技巧总结
2017/02/27 Javascript
angularjs实现猜数字大小功能
2020/05/20 Javascript
javascript中this的用法实践分析
2019/07/29 Javascript
python解决方案:WindowsError: [Error 2]
2016/08/28 Python
python机器学习之随机森林(七)
2018/03/26 Python
Python集中化管理平台Ansible介绍与YAML简介
2019/06/12 Python
Python项目 基于Scapy实现SYN泛洪攻击的方法
2019/07/23 Python
Tensorflow中的dropout的使用方法
2020/03/13 Python
jupyter note 实现将数据保存为word
2020/04/14 Python
CSS3新增布局之: flex详解
2020/06/18 HTML / CSS
5分钟实现Canvas鼠标跟随动画背景
2019/11/18 HTML / CSS
MyFrenchPharma中文网:最大的法国药妆平台
2016/10/07 全球购物
澳大利亚在线消费电子产品商店:TobyDeals
2020/01/05 全球购物
比较基础的php面试题及答案-填空题
2014/04/26 面试题
留学自荐信
2013/10/10 职场文书
cf战队收人广告词
2014/03/14 职场文书
机械制造专业大学生自我鉴定
2014/09/19 职场文书
2014年个人工作总结模板
2014/12/15 职场文书
欢迎词范文
2015/01/27 职场文书
后勤工作个人总结
2015/02/28 职场文书
2015年国庆节标语大全
2015/07/30 职场文书
2016国庆节67周年红领巾广播稿
2015/12/18 职场文书
SpringBoot生成License的实现示例
2021/06/16 Java/Android