element-ui(vue2) 和element-plus(vue3) el-menu如何设置选中值

1、element-ui (用的vue2)

this.$refs.menuList.activeIndex

2、element-plus (用的vue3)

v-model 双向绑定,直接赋值

<template>
  <el-menu :default-active="activeIndex" class="el-menu-demo" mode="horizontal" @select="handleSelect" ref="elMenus"  v-model="activeIndex">
    <div v-for="(item, index) in store.routes" :key="index">
      <template v-if="!item.subMenu">
        <el-menu-item :index="`${index}`" class="menu_title1">
          <div class="menu_t">{{ item.title }}</div>
        </el-menu-item>
      </template>
      <template v-else>
        <el-sub-menu :index="`${index}`" class="menu_title1">
          <template #title>
            <div class="menu_t">{{ item.title }}</div>
          </template>
          <el-menu-item v-for="(subitem, subindex) in item.subMenu" :key="`${index}-${subindex}`"
            :index="`${index}-${subindex}`">{{ subitem.title }}</el-menu-item>
        </el-sub-menu>
      </template>
    </div>
  </el-menu>
</template>
<script setup>
import { ref } from "vue";
import { useUserStore } from "@/stores";
const elMenus = ref(null)
const store = useUserStore();
const emits = defineEmits([
  "toggleMenu",
]);
const activeIndex = ref("0");
activeIndex.value="1"//设置被选中的菜单
</script>

要在Vue 3和Element Plus中实现三级菜单,你可以按照以下步骤进行配置: 1. 首先,在App.vue文件中配置顶栏,可以使用`<el-menu>`组件来创建多级菜单。在`<template>`标签中添加如下代码: ```html <div id="nav"> <div class="h-6" /> <el-menu default-active="/keng" class="el-menu-demo" mode="horizontal" background-color="#545c64" text-color="#fff" active-text-color="#ffd04b" router> <el-menu-item index="/dyg1">用户</el-menu-item> <el-menu-item index="/deg1">教学</el-menu-item> <el-menu-item index="/dsg1">题库</el-menu-item> </el-menu> <router-view/> </div> ``` 2. 其次,在需要设置侧边栏的页面中,可以使用`<el-menu>`组件来创建多级菜单。在`<template>`标签中添加如下代码: ```html <div class=''> <el-col :span="4"> <el-menu default-active="/yongh" class="el-menu-vertical-demo" background-color="#545c64" text-color="#fff" active-text-color="#ffd04b" router> <el-menu-item index="/dyg2"> <span>学员管理</span> </el-menu-item> <el-menu-item index="/dyg3"> <span>助教管理</span> </el-menu-item> </el-menu> </el-col> <el-col :span="20"> <router-view></router-view> </el-col> </div> ``` 3. 另外,如果你想动态渲染多级菜单,可以参考Vue Element-UI官方文档中提供的组件示例。 4. 最后,在router/index.js文件中设置路由,可以使用`const routes`来定义路由的路径和对应的组件。下面是一个示例代码: ```javascript const routes = [ { path: '/', redirect: '/dyg1', // 设置路由重定向第一次进入的页面 }, { path: '/dyg1', name: 'dyg1', component: () => import('../views/dyg/dyg1.vue'), children: [ { path: '/dyg2', name: 'dyg2', component: () => import('../views/dyg/dyg2.vue'), }, { path: '/dyg3', name: 'dyg3', component: () => import('../views/dyg/dyg3.vue'), }, ], }, ]; ``` 通过以上步骤,你可以在Vue 3和Element Plus中实现三级菜单的功能。<span class="em">1</span><span class="em">2</span><span class="em">3</span><span class="em">4</span>
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值