关于element导航菜单使用for循环出来,展开一个菜单项,其余也都打开的问题

问题描述

使用element导航菜单时,使用v-for循环出来的每一项,打卡一个菜单项时发现其他项也都打开了,是因为<el-menu>标签是根据index来定位展开还是关闭的,而使用v-for循环使得每一项的index都是一样的,所以才会一个打开都打开

解决办法

只需要在循环时,给每一项添加唯一index就可以了,每一项都有自己的唯一id,所以将id作为index,加空字符串是因为index只接受字符串,而id是数字,拼接空字符串可以使数字转为字符串。

<el-submenu v-for="(item,index) in resources" :key="index" :index="item.id + '' "></el-submenu>
  • 5
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是一个使用element-ui的v-for循环el-form-item的组件代码示例: ```vue <template> <el-form> <el-form-item v-for="(field, index) in fields" :key="index" :label="field.label"> <el-input v-model="field.value" :placeholder="field.placeholder"></el-input> </el-form-item> </el-form> </template> <script> export default { props: { fields: { type: Array, required: true, default: () => [], }, }, }; </script> ``` 在上述代码中,我们使用一个props属性来接收一个名为fields的数组,该数组中包含了每个表单项的label、placeholder和value属性。我们使用v-for循环该数组,并将其作为el-form-item的子组件,每个el-form-item包含了一个el-input组件,用于输入表单项的值。最后,我们将整个表单包裹在一个el-form组件中。 使用该组件时,我们只需要传递一个包含所有表单项的数组即可: ```vue <template> <my-form :fields="fields"></my-form> </template> <script> import MyForm from "@/components/MyForm.vue"; export default { components: { MyForm, }, data() { return { fields: [ { label: "姓名", placeholder: "请输入姓名", value: "", }, { label: "邮箱", placeholder: "请输入邮箱", value: "", }, { label: "电话", placeholder: "请输入电话", value: "", }, ], }; }, }; </script> ``` 在上述代码中,我们引入了刚才创建的MyForm组件,并将fields数组传递给该组件的props属性。fields数组中包含了三个表单项,分别是姓名、邮箱和电话。我们可以通过该组件来快速创建包含多个表单项的表单。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值