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

相关推荐
kyriewen6 小时前
写组件文档写到吐?我用AI自动生成Storybook,同事以后直接抄
前端·javascript·面试
五点六六六7 小时前
你敢信这是非Native页面写出来的渐变效果吗🌝(底层原理解析
前端·javascript·面试
吃西瓜的年年8 小时前
TypeScript
javascript·ubuntu·typescript
独泪了无痕9 小时前
CryptoJS:数据安全的JavaScript加密利器
前端·vue.js·node.js
熊猫_豆豆11 小时前
一个模拟四轴飞行器在随机气流扰动下悬停飞行的交互式3D仿真网页,包含飞行器建模与PID控制算法
javascript·3d·html·四轴无人机模拟飞行
来恩100312 小时前
jQuery选择器
前端·javascript·jquery
前端繁华如梦12 小时前
树上挂苹果还是挂玻璃球?Three.js 程序化果实的完整实现指南
前端·javascript
CDwenhuohuo12 小时前
优惠券组件直接用 uview plus
前端·javascript·vue.js
川冰ICE13 小时前
TypeScript装饰器与元编程实战
前端·javascript·typescript
AI砖家13 小时前
Vue3组件传参大全,各种传参方式的对比
前端·javascript·vue.js