VUE el-select Select 选择器 选项是对象,显示是一个值name ,但是绑定的对象值是id方案

在 Vue 中使用 Element UI 的 el-select 组件时,如果希望显示对象的某个属性(如 name),但实际绑定的是对象的另一个属性(如 id),需要使用 value-key 和 label 属性来分别指定这两个属性。但是,Element UI 的 el-select 组件并没有直接的 value-key 属性。不过,可以通过 v-model 绑定、:label 属性和自定义模板来实现这个需求。

以下是一个示例,说明如何在 el-select 中实现这个需求:

  1. 假设有一个对象数组,每个对象都有 id 和 name 属性。
javascript 复制代码
data() {  
  return {  
    options: [  
      { id: 1, name: 'Option 1' },  
      { id: 2, name: 'Option 2' },  
      // ... 其他选项  
    ],  
    selectedId: null // 用于绑定选择的值(对象的id)  
  };  
}
  1. 使用 el-select 并结合 v-model、:label 和自定义的 el-option 模板来实现。
javascript 复制代码
<template>  
  <el-select v-model="selectedId" placeholder="请选择">  
    <el-option  
      v-for="item in options"  
      :key="item.id"  
      :label="item.name"  
      :value="item.id">  
    </el-option>  
  </el-select>  
</template>

在这个示例中,v-model="selectedId" 用于绑定选择的值,该值将是选中项的 id。:label="item.name" 用于指定在选项中显示的文本,即对象的 name 属性。:value="item.id" 指定了当该选项被选中时,v-model 绑定的值将是什么。

当用户选择一个选项时,selectedId 将被更新为选中项的 id,而 el-select 下拉列表中显示的是每个选项的 name 属性。

相关推荐
豹哥学前端8 分钟前
前端工程化实战:从包管理到 Vite 配置,一套下来全明白
前端·javascript·vite
干中学_202637 分钟前
vue3 画布编辑器「平移」天坑?只需 5 行代码,完美优雅复刻大厂体验!
javascript
大家的林语冰2 小时前
Canvas 文艺复兴,HTML-in-Canvas 炫酷特效摆拍走红,Canvas 中也能渲染交互式的 HTML 元素了
前端·javascript·html
前端那点事4 小时前
彻底解决KeepAlive缓存乱象!Vue3精细化按需缓存+路径重置终极方案
前端·vue.js
前端那点事4 小时前
Vue 的 template 标签不能用 v-show?底层机制+踩坑复盘+生产级解决方案
前端·vue.js
前端那点事4 小时前
从零落地前端性能优化:全链路避坑+实战调优方案
前端·vue.js
2401_865439634 小时前
CSS中隐藏元素的多重技巧与应用场景
开发语言·前端·javascript
烛衔溟4 小时前
TypeScript 中的类基础
javascript·ubuntu·typescript
Momo__5 小时前
Vue3 v-memo:长列表渲染的性能核武器
前端·vue.js