前言
因业务需要,在下拉框选中后需同时传value和label,还有其他属性值,遂进行研究。
主体
上酸菜 代码
<!--value-key的值对应于item里的唯一字段(2021.02.11)-->
<el-select v-model="founder" clearable
@change="changeFounder" value-key="customerId"
placeholder="请选择">
<el-option
v-for="item in founderNames"
:key="item.customerId"
:label="item.customerName"
:value="item">
</el-option>
</el-select>
相对于普通下拉框,你只要把 :value 的值改成item , 再加个value-key就可以了,你的 v-model 获取到的值就是选中的那个对象。
注意
value-key的值需要具有唯一性,不然会出现多个项目都被选中(字体为绿色)的错误情况。建议跟 :key 的值保持一致。
延伸
除上述方法外,
1、还可以通过@change函数,用find方法拿到选中的值。
参考 vue基于elementUI下拉Select同时获取value和label的值
2、可以直接把要用的值放在 :value里,感觉比较low…,不过能解决问题的方法就是好方法。
参考 vue下拉框向后台同时传value和label值
后记
本想着是个骚操作,结果骚到自己了。。。别人传的参数不能直接通过commit传到界面。。。就很尴尬。。。
重回find的怀抱。。。