el-select设置对象为value选中错误

  1. 通过设置value-key来绑定唯一值,建议使用对象的id
    文档建议

2、如果在 el-select 中设置了 value-key,但是仍然无法正确选中对象类型的值,可能是因为在 value 中传递了一个引用地址。

解决该问题的方法是,在 v-model 中使用一个新的对象类型的值来绑定选中的对象,确保 v-model 中绑定的值与选项列表中的对象不是同一个引用地址。例如,可以使用 lodash 库中的 cloneDeep 方法,将选中的对象克隆一份新的来作为 v-model 中的绑定值。

以下是一个示例代码实现:

<template>
  <el-select v-model="selectedItem" v-bind:value-key="valueKey">
    <el-option v-for="item in options" :key="item.id" :label="item.label" :value="item"></el-option>
  </el-select>
</template>
<script>
import _ from 'lodash'

export default {
  data() {
    return {
      valueKey: 'id',
      options: [
        {id: 1, label: '选项1'},
        {id: 2, label: '选项2'},
        {id: 3, label: '选项3'}
      ],
      selectedItem: {} // 选中的对象
    }
  },
  watch: {
    // 监听选中项的变化
    selectedItem: {
      handler(newVal) {
        console.log(newVal); // 输出选中的对象
      },
      deep: true // 深度监听对象的变化
    }
  },
  mounted() {
    // 将选中的对象克隆一份新的来绑定到 v-model 上
    this.selectedItem = _.cloneDeep(this.options[0])
  }
}
</script>

在上述代码中,通过使用 watch 来监控选中的对象的变化。在 mounted 钩子函数里,首先将 this.options[0](即 “选项1”)克隆一份新的对象,然后将它赋值给 this.selectedItem。这样就可以确保 v-model 中绑定的值与 options 中的对象不是同一个引用地址了。

需要注意的是,如果将 v-model 中的值设置为对象类型,需要开启 deep 模式来深度监听对象变化,否则无法在选中对象中修改属性时触发 watch 监听。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值