解决element-ui的下拉框有值却⽆法选中的情况
问题描述:
在使⽤Vue框架和element-ui开发时,下拉框遇见⼀个问题,在函数中改变了页⾯中的某个值,在函数中查看是修改成功了,但在页⾯中没有及时刷新改变后的值,也就是下拉框值⽆法选中。(踩坑踩得莫名其妙)
代码段:
<el-select v-model="value" placeholder="请选择" @change="change()">
<el-option v-for="item in options" :key="item.value" :label="item.label" :value="item.value"></el-option>
</el-select>
解决⽅法:
出现这个问题好像是因为下拉框数据是循环掉别的接⼝得来的,因为数据层次太多,render函数没有⾃动更新,需⼿动强制刷新所以我直接强制刷新了值,⽽forceUpdate就是重新render。
写⼀个⽅法,在select的change事件中调⽤此⽅法,运⽤ this.$forceUpdate()强制刷新,页⾯正常选值。
jquery获取下拉框选中值
change(){
this.$forceUpdate()
},
⼩结:
同理,forceUpdate()这个⽅法也适⽤⼀些很深的组件 state 已经改变了的时候,可以在该组件上⾯调⽤,解决页⾯v-for中修改item属性值后页⾯页⾯值不改变的问题。
补充知识:解决element ui select多选下拉框,在编辑表单记录时没有回显数据,默认选中的问题
前端使⽤vue,项⽬中使⽤的是element ui组件,在使⽤select下拉框多选时,新增记录时select多选下拉框正常使⽤,没问题。但是在编辑记录时,编辑界⾯也为select下拉框赋值了,却没有显⽰数据。
先放⼀个select多选下拉框编辑时正确的加载数据的显⽰效果图:
下拉框代码如下:
<el-form-item prop="czfaIds" label="处置⽅案">
<el-select v-model="faIds" multiple placeholder="请选择" clearable :disabled="showControl">
<el-option
v-for="item in czfas"
:key="item.value"
:label="item.wsdFamc"
:value="item.id"
/>
</el-select>
</el-form-item>
下拉框中的数据源czfas是⼀个数组,选中后的值也是⼀个数组。但是在后端存储的时候是转换成字符串存到数据库中的,所以在编辑界⾯从后端获取的返回值是⼀个字符串,⾸选要把这个字符串转换成数组,绑定到select 的v-model属性上。
代码如下:
// 编辑
queryEditRow(index, row) {
this.titleInfo = '编辑'
this.dialogVisible = true
this.form = Object.assign({}, row)
// 将字符串转换成数组,绑定到select控件的v-model属性上
faIds = faIds.split(',')
this.showbtn = true
this.showControl = false
},
但是发现还是有问题,显⽰的是选中的⽅案的id值,⽽且没有将选择的选项选中。
如下图:
分析:select选择器对数据的显⽰,是匹配到select下拉框数据源中对应的value值时则会显⽰相应的label;若是没有匹配到,则显⽰的是该value。
显然,这⾥是因为没有匹配到下拉框中的value值,直接显⽰的这个字段的值。
在浏览器控制台中输出数据源的数据:
在浏览器控制台输出返回的字符串转换成数组后的值:
发现select下拉框中的id 和 v-mode⾥边绑定的id的数据类型不⼀致,虽然数据的值是⼀样的,但是⼀个是字符串,⼀个是整型数值。将后端返回的字符串在转换成数组时,转换成整形数组,下拉框即可正确显⽰。
代码如下:
// 编辑
queryEditRow(index, row) {
this.titleInfo = '编辑'
this.dialogVisible = true
this.form = Object.assign({}, row)
// 将字符串转换成数组,此时是字符串数组
var arrStringCzfaIds = faIds.split(',')
// 将字符串数组的每⼀项转换成Number,⽣成⼀个新的数组
var arrIntCzfaIds = []
for (var arrInt in arrStringCzfaIds) {
arrIntCzfaIds.push(parseInt(arrStringCzfaIds[arrInt]))
}
// 将新的Number数组,绑定到select空间的v-model上
faIds = arrIntCzfaIds
this.showbtn = true
this.showControl = false
},
此时,显⽰的效果就是本⽂开头的效果了。
以上这篇解决element-ui的下拉框有值却⽆法选中的情况就是⼩编分享给⼤家的全部内容了,希望能给⼤家⼀个参考,也希望⼤家多多⽀持。

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。