Vue3 Element-plus和el-menu无限级菜单组件如何封装

本文小编为大家详细介绍“Vue3 Element-plus和el-menu无限级菜单组件如何封装”,内容详细,步骤清晰,细节处理妥当,希望这篇“Vue3 Element-plus和el-menu无限级菜单组件如何封装”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。

成都创新互联专业为企业提供宜阳网站建设、宜阳做网站、宜阳网站设计、宜阳网站制作等企业网站建设、网页设计与制作、宜阳企业网站模板建站服务,10余年宜阳做网站经验,不只是建网站,更提供有价值的思路和整体网络服务。

对于element中提供给我们的el-menu组件最多可以实现三层嵌套,如果多一层数据只能自己通过变量去加一层,如果加了两层、三层这种往往是行不通的,所以只能进行封装

Vue3 Element-plus和el-menu无限级菜单组件如何封装
效果图

一、定义数据

MenuData.ts

export default [
    {
        id: "1",
        name: "第一级菜单",
        level: '1',
        child: [
            {
                id: "11",
                name: "第二级菜单",
                level: '1-1',
                child: [
                    {
                        id: "111",
                        name: "第三级菜单",
                        level: '1-1-1',
                        child: [
                            {
                                id: "1111",
                                name: "第四级菜单",
                                level: '1-1-1-1',
                                child: [
                                    {
                                        id: "11111",
                                        name: "第五级菜单",
                                        level: '1-1-1-1-1',
                                        child: []
                                    }
                                ]
                            }
                        ]
                    }]
            }
        ]
    },
    {
        id: "2",
        name: "第一级同级菜单",
        level: '2',
        child: []
    }
 
]

二、封装组件

封装思想:

1.对本身组件进行循环使用,如果有子集使用本身组件 把child数据传给自己

2.如果没有子集 使用 el-menu-item

以下代码对setup( )函数和setup语法糖分别做了实现

setup语法糖


          
        
      
      
      
        
          
          
           {{ generateSpaces(item.level) }} 
          {{ item.name }}
        
      
    
  

 

// 把下面代码变成setup语法糖的形式 
import type { PropType } from "vue";
import type { MenuItem } from "@/types/lesson";
// type 为了方便写成这样 可以根据自己项目设定type
 defineProps({
  menu: {
    type: Array as unknown as PropType,
    required: true,
    default: () => [],
  },
  defaultActive: {
    type: String as unknown as PropType,
    required: true,
    default: [],
  },
});
 
const emit = defineEmits(["update-active-path", "clickItem"]);
 
// 返回的空格字符串 用于显示菜单层级 
const generateSpaces = (level: string) => {
  let str = "";
  level.split("")  .filter((it) => it != "-") .forEach(() => {
      str += " ";
  });
  return str;
};
 
// 点击当前菜单项
const clickItemHandle = (item: MenuItem) => {
  emit("clickItem", item);
};

 

.el-menu {
  width: 288px;
}

setup函数


            
          
        
        
          
            
            
             {{ generateSpaces(item.level) }} 
            {{ item.name }}
          
        
      
  

 

import { defineComponent, toRefs } from 'vue';
import type { PropType } from 'vue'
import type {MenuItem} from '@/types/lesson'
export default defineComponent({
  name: 'MenuTree',
  props: {
    menu: {
      type: Array as unknown as PropType,
      required: true,
      default: () => [],
    },
    defaultActive: {
      type: String as unknown as PropType,
      required: true,
      default: '',
    },
  },
  emits: ['update-active-path','clickItem'],
  setup(props, context) {
    const { menu, defaultActive } = toRefs(props);
 
    const generateSpaces = (level:string) => {
      let str = ''
      level.split('').filter(it=>it!='-').forEach(() => {
        str += ' '
      })
      return str
    }
 
    const clickItemHandle = (item:MenuItem) => {
      context.emit('clickItem', item)
    }
 
   
    return {
      clickItemHandle,
      menu,
      defaultActive,
      generateSpaces,
    }
  },
});

 

  .el-menu {
    width: 288px;
  }

type就不补充了 可根据自己项目定义,可临时改成any

三、使用组件


 

import MenuTree from "./components/MenuTree.vue";
import type {MenuItem} from '@/types/lesson'
import menuData from './MenuData'
 
const defaultActive = ref(''); // "1-1-1-1" 默认选中的数据
const menuList = ref(menuData)
 
const handleMenuClick = (item:MenuItem) => {
  console.log('父组件',item);
};

补充default-active变量,如果一开始想默认点开第一层的数据 就需要找规律啦

拿到所有的level,通过接口方式返给你 自己平铺拿到所有的level也好

例如数据格式:

let arr = [  "1-1",
  "1-1-1",
  "1-1-1-1",
  "1-1-1-2",
  "1-1-1-3",
  "1-1-1-4",
  "1-1-1-5",
  "1-1-1-6",
  "1-1-2",
  "1-1-2-1"
]

想要的结果就是 最长且相同数字最多的元素 1-1-1-1

arr.sort((a,b)=> b.split('-').length - a.split('-').length)[0]

使用split防止有些字符串是10、11 两位数字的

读到这里,这篇“Vue3 Element-plus和el-menu无限级菜单组件如何封装”文章已经介绍完毕,想要掌握这篇文章的知识点还需要大家自己动手实践使用过才能领会,如果想了解更多相关内容的文章,欢迎关注创新互联行业资讯频道。


文章标题:Vue3 Element-plus和el-menu无限级菜单组件如何封装
文章地址:http://scyanting.com/article/ihoihs.html