前言
因业务需要,在下拉框选中后需同时传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的怀抱。。。

Logo

前往低代码交流专区

更多推荐