Element Plus 组件库 - Select 选择器 value 为 index 时的一些问题

Select 选择器 value 为 index 时的一些问题

html 复制代码
<el-select v-model="packageSelect" placeholder="请选择升级包">
    <el-option v-for="(item, index) in packages" :key="item.id" :label="`${item.packageName}(${item.host})`" :value="index" />
</el-select>

<el-button @click="deleteFirstItem">删除第一项(模拟数据变化)</el-button>
<el-button @click="showSelectedInfo">显示当前选中信息</el-button>
js 复制代码
const packageSelect = ref(null);

const packages = ref([
    { id: 1, packageName: "升级包 A", host: "192.168.1.1" },
    { id: 2, packageName: "升级包 B", host: "192.168.1.2" },
    { id: 3, packageName: "升级包 C", host: "192.168.1.3" },
]);

const deleteFirstItem = () => {
    packages.value.shift();
};

const showSelectedInfo = () => {
    if (packageSelect.value === null) {
        console.log("请先选择一个项");
        return;
    }

    const selectedItem = packages.value[packageSelect.value];

    console.log("当前选中的项:", selectedItem);
};
  1. 用户选择"升级包 A",此时,packageSelect 为 1,点击"显示当前选中信息",输出结果如下

    当前选中的项: Proxy(Object) {id: 2, packageName: '升级包 B', host: '192.168.1.2'}

  2. 点击"删除第一项"后,数据变为如下

js 复制代码
[
    { id: 2, packageName: "升级包 B", host: "192.168.1.2" },
    { id: 3, packageName: "升级包 C", host: "192.168.1.3" },
]
  1. 此时,packageSelect 任然为 1,点击"显示当前选中信息",输出结果如下

    当前选中的项: Proxy(Object) {id: 3, packageName: '升级包 C', host: '192.168.1.3'}

  • 问题是用户原本选择的是"升级包 B",数据变化后,选择变成了"升级包 C"

解决方案

  1. 使用唯一标识符作为 value 值
html 复制代码
<el-select v-model="packageSelect" placeholder="请选择升级包">
    <el-option v-for="item in packages" :key="item.id" :label="`${item.packageName}(${item.host})`" :value="item.id" />
</el-select>

<el-button @click="deleteFirstItem">删除第一项(模拟数据变化)</el-button>
<el-button @click="showSelectedInfo">显示当前选中信息</el-button>
js 复制代码
const packageSelect = ref(null);

const packages = ref([
    { id: 1, packageName: "升级包 A", host: "192.168.1.1" },
    { id: 2, packageName: "升级包 B", host: "192.168.1.2" },
    { id: 3, packageName: "升级包 C", host: "192.168.1.3" },
]);

const deleteFirstItem = () => {
    packages.value.shift();
};

const showSelectedInfo = () => {
    if (packageSelect.value === null) {
        console.log("请先选择一个项");
        return;
    }

    const selectedItem = packages.value.find((item) => item.id === packageSelect.value);

    console.log("当前选中的项:", selectedItem);
};
  1. 使用拼接后的字符串作为 value 值
html 复制代码
<el-select v-model="packageSelect" placeholder="请选择升级包">
    <el-option v-for="item in packages" :key="item.packageName + item.host" :label="`${item.packageName}(${item.host})`" :value="item.packageName + item.host" />
</el-select>

<el-button @click="deleteFirstItem">删除第一项(模拟数据变化)</el-button>
<el-button @click="showSelectedInfo">显示当前选中信息</el-button>
js 复制代码
const packageSelect = ref(null);

const packages = ref([
    { packageName: "升级包 A", host: "192.168.1.1" },
    { packageName: "升级包 B", host: "192.168.1.2" },
    { packageName: "升级包 C", host: "192.168.1.3" },
]);

const deleteFirstItem = () => {
    packages.value.shift();
};

const showSelectedInfo = () => {
    if (packageSelect.value === null) {
        console.log("请先选择一个项");
        return;
    }

    const selectedItem = packages.value.find((item) => item.packageName + item.host === packageSelect.value);

    console.log("当前选中的项:", selectedItem);
};
  1. 使用 index 作为 value 值,同时在数据变化时,手动将 packageSelect 重置为 null
html 复制代码
<el-select v-model="packageSelect" placeholder="请选择升级包">
    <el-option v-for="(item, index) in packages" :key="item.id" :label="`${item.packageName}(${item.host})`" :value="index" />
</el-select>

<el-button @click="deleteFirstItem">删除第一项(模拟数据变化)</el-button>
<el-button @click="showSelectedInfo">显示当前选中信息</el-button>
js 复制代码
const packageSelect = ref(null);

const packages = ref([
    { id: 1, packageName: "升级包 A", host: "192.168.1.1" },
    { id: 2, packageName: "升级包 B", host: "192.168.1.2" },
    { id: 3, packageName: "升级包 C", host: "192.168.1.3" },
]);

const deleteFirstItem = () => {
    packages.value.shift();
    packageSelect.value = null;
};

const showSelectedInfo = () => {
    if (packageSelect.value === null) {
        console.log("请先选择一个项");
        return;
    }

    const selectedItem = packages.value[packageSelect.value];

    console.log("当前选中的项:", selectedItem);
};
相关推荐
MSTcheng.6 分钟前
【C++】C++11新特性(二)
java·开发语言·c++·c++11
晓13139 分钟前
第七章 【C语言篇:文件】 文件全面解析
linux·c语言·开发语言
愚者游世9 分钟前
Delegating Constructor(委托构造函数)各版本异同
开发语言·c++·程序人生·面试·改行学it
一 乐10 分钟前
校园二手交易|基于springboot + vue校园二手交易系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·后端
梵刹古音11 分钟前
【C语言】 指针基础与定义
c语言·开发语言·算法
Ekehlaft14 分钟前
这款国产 AI,让 Python 小白也能玩转编程
开发语言·人工智能·python·ai·aipy
rit843249917 分钟前
MATLAB中Teager能量算子提取与解调信号的实现
开发语言·matlab
开源技术19 分钟前
Python GeoPandas基础知识:地图、投影和空间连接
开发语言·ide·python
科技D人生20 分钟前
Vue.js 学习总结(20)—— Vue-Office 实战:word、pdf、excel、ppt 多种文档的在线预览
vue.js·word·vue-pdf·stylesheet·docx-preview·vue-office
vx1_Biye_Design21 分钟前
基于Spring Boot+Vue的学生管理系统设计与实现-计算机毕业设计源码46223
java·vue.js·spring boot·spring·eclipse·tomcat·maven