el-menu的使用(记录一下使用数组数据的情况)

做项目时遇到需要菜单项显示提示红点的场景,浅浅记录一下思路~

    <el-menu :default-openeds="openeds"  class="el-menu-vertical-demo" @open="handleOpen"  @close="handleClose"     text-color="#fff" active-text-color="#333" :unique-opened="true">
           <template v-for="item in menu"  >
             <template  v-if="item.is_sub" >
              <el-submenu :index="item.index" >
               <template slot="title">
                <i class="el-icon-location"></i>
                <span>{{item.title}}</span>
               </template>
               <el-menu-item-group>  
                <template v-for="item1 in item.sub_item">
                  <router-link :to="item1.to">
                   <el-menu-item :index="item1.index" v-if="item1.authority()"  :key="item1.index">
                     <span class="badge">
                      <el-badge class="dot" is-dot :hidden="item1.is_dot"></el-badge>{{item1.title}}
                     </span>
                   </el-menu-item>
                  </router-link>
                </template>
              </el-menu-item-group>
             </el-submenu>
            </template>
            <template v-else>
             <router-link   :to="item.to" v-if="item.authority">
              <el-menu-item index="4" >
               <i class="el-icon-s-home"></i>
               <span slot="title">首页</span>
               </el-menu-item>
             </router-link>
            </template>
          </template>
        </el-menu> 

js

<script>
export default {
  name: 'app',
  data () {
    return {
      node_list:storage.get('meun').node_list, //获得授权节点,
      menu:[
        {is_sub:false,
         title:'首页',
         index:'4',
         to:"/get_Data/getStatisticsByOrder",
        },
        {is_sub:true,
         title:'用户管理',
         index:'9',
         sub_item:[
            {title:'角色列表',index:'9-1',authority:()=>{return this.node_list[1].indexOf('user_auth_list') != -1},to:"/user/auth_list",is_dot:false},
            {title:'用户列表',index:'9-2',authority:()=>{return this.node_list[2].indexOf('user_getuserlist') != -1},to:"/user/user_list",is_dot:false},
            {title:'所有节点',index:'9-3',authority:()=>{return this.node_list[1].indexOf('user_get_node_list') != -1},to:"/user/node_list",is_dot:true}]
        },
        {is_sub:true,
         title:'公告管理',
         index:'1',
         sub_item:[
            {title:'新建公告',index:'1-1',authority:()=>{return this.node_list[1].indexOf('message_addmessage') != -1},to:"/Message/addMessage/0",is_dot:true},
            {title:'公告列表',index:'1-2',authority:()=>{return this.node_list[1].indexOf('message_getlist') != -1},to:"/Message/MessageList",is_dot:false},
            {title:'公告发送记录',index:'1-3',authority:()=>{return this.node_list[1].indexOf('message_getmsgreceive') != -1},to:"/Message/getMsgReceive",is_dot:false}]}
      ],
      openeds:['9']
    }
  }
 }
</script>
  • 7
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值