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 属性。

相关推荐
kyriewen1 天前
别再 console.log 了:5 个 Chrome DevTools 调试技巧,用过就回不去了
前端·javascript·面试
To_OC1 天前
LC 1 两数之和:面试第一道必考题,暴力解法直接被面试官 pass
javascript·算法·leetcode
GuWenyue1 天前
排序效率低?5分钟吃透快速排序,性能飙升至O(nlogn)
前端·javascript·面试
OpenTiny社区1 天前
🎨 看完 GenUI SDK 源码我悟了!
前端·vue.js·github
何时梦醒1 天前
深入理解递归与快速排序 —— 从基础入门到手写实现
前端·javascript
bonechips1 天前
LLM 的无状态:从 HTTP 协议到对话上下文工程
前端·javascript
胡志辉1 天前
从 prototype 到 V8,看懂 JavaScript 原型链
前端·javascript
mqcode2 天前
你项目里的 axios,封对了吗?从裸用到生产级的四步进化
vue.js·axios
ping某2 天前
专栏-null 和 undefined 到底是什么?
前端·javascript·后端
Linsk2 天前
组件 = 模板 + 业务逻辑
java·前端·vue.js