vue中使用的element-ui的动态select,不能选择重复数据

<template>
    <template v-slot:form="{ item }">
        <el-row v-for="(dishesIngredient, index) in parArr" :key="index">
          <el-form-item :label="'原料'+(index+1)" :prop="'data.ingredients.'+index+'.ingredientId'" :rules="{required: true, message:'原料不能为空', trigger: 'blur'}">
            <el-select v-model="dishesIngredient.ingredientId" clearable :placeholder="`请选择原料`" @change="handleIngredientListChange($event, index)">
              <el-option v-for="ingredient in ingredientList" v-show="dishesIngredient.ingredientId == ingredient.ingredientId || !selectIdsArr.includes(ingredient.ingredientId)" :key="ingredient.ingredientId" :label="ingredient.ingredientName" :value="ingredient.ingredientId" />
            </el-select>
          </el-form-item>
        </el-row>
      </template>
</template>
<script>
export default {
    data() {
        selectIdsArr:[],
        parArr:[{guid:'ddddd',ingredientId:null,},{guid:'eeeee',ingredientId:null,},{guid:'ffff',ingredientId:null,}],
        programList:[{
        "ingredientId":1,
        "ingredientName":"选项1"
      },{
        "ingredientId":2,
        "ingredientName":"选项2"
      },{
        "ingredientId":3,
        "ingredientName":"选项3"
      }],
    },
    methods:{
        // 切换原料
    handleIngredientListChange(id, index) {
      this.selectIdsArr = []
      const ingredients = parArr
      for (const item of ingredients) {
        if (item.ingredientId) {
          this.selectIdsArr.push(item.ingredientId)
        }
      }
    },
    }
}
</script>

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值