解决element-ui的下拉框有值却无法选中的情况


Posted in Javascript onNovember 07, 2020

问题描述:

在使用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()强制刷新,页面正常选值。

change(){
   this.$forceUpdate()
 },

小结:

同理,forceUpdate()这个方法也适用一些很深的组件 state 已经改变了的时候,可以在该组件上面调用,解决页面v-for中修改item属性值后页面页面值不改变的问题。

补充知识:解决element ui select多选下拉框,在编辑表单记录时没有回显数据,默认选中的问题

前端使用vue,项目中使用的是element ui组件,在使用select下拉框多选时,新增记录时select多选下拉框正常使用,没问题。但是在编辑记录时,编辑界面也为select下拉框赋值了,却没有显示数据。

先放一个select多选下拉框编辑时正确的加载数据的显示效果图:

解决element-ui的下拉框有值却无法选中的情况

下拉框代码如下:

<el-form-item prop="czfaIds" label="处置方案">
 <el-select v-model="form.czfaIds" multiple style="width:80%;" 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属性上
   this.form.czfaIds = row.czfaIds.split(',')

   this.showbtn = true
   this.showControl = false
  },

但是发现还是有问题,显示的是选中的方案的id值,而且没有将选择的选项选中。

如下图:

解决element-ui的下拉框有值却无法选中的情况

分析:select选择器对数据的显示,是匹配到select下拉框数据源中对应的value值时则会显示相应的label;若是没有匹配到,则显示的是该value。

显然,这里是因为没有匹配到下拉框中的value值,直接显示的这个字段的值。

在浏览器控制台中输出数据源的数据:

解决element-ui的下拉框有值却无法选中的情况

在浏览器控制台输出返回的字符串转换成数组后的值:

解决element-ui的下拉框有值却无法选中的情况

发现select下拉框中的id 和 v-mode里边绑定的id的数据类型不一致,虽然数据的值是一样的,但是一个是字符串,一个是整型数值。将后端返回的字符串在转换成数组时,转换成整形数组,下拉框即可正确显示。

代码如下:

// 编辑
  queryEditRow(index, row) {
   this.titleInfo = '编辑'
   this.dialogVisible = true
   this.form = Object.assign({}, row)

   // 将字符串转换成数组,此时是字符串数组
   var arrStringCzfaIds = row.czfaIds.split(',')
   // 将字符串数组的每一项转换成Number,生成一个新的数组
   var arrIntCzfaIds = []
   for (var arrInt in arrStringCzfaIds) {
    arrIntCzfaIds.push(parseInt(arrStringCzfaIds[arrInt]))
   }
   // 将新的Number数组,绑定到select空间的v-model上
   this.form.czfaIds = arrIntCzfaIds

   this.showbtn = true
   this.showControl = false
  },

此时,显示的效果就是本文开头的效果了。

以上这篇解决element-ui的下拉框有值却无法选中的情况就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
通过jQuery打造支持汉字,拼音,英文快速定位查询的超级select插件
Jun 18 Javascript
自己动手制作jquery插件之自动添加删除行功能介绍
Oct 14 Javascript
JavaScript Math.ceil() 函数使用介绍
Dec 11 Javascript
js调试系列 控制台命令行API使用方法
Jun 18 Javascript
浅析AMD CMD CommonJS规范--javascript模块化加载学习心得总结
Mar 16 Javascript
AngularJS上拉加载问题解决方法
May 23 Javascript
利用jQuery的动画函数animate实现豌豆发射效果
Aug 28 Javascript
js中Number数字数值运算后值不对的解决方法
Feb 28 Javascript
JS实现图片手风琴效果
Apr 17 Javascript
详解webpack2异步加载套路
Sep 14 Javascript
Bootstarp在pycharm中的安装及简单的使用方法
Apr 19 Javascript
vue 使用element-ui中的Notification自定义按钮并实现关闭功能及如何处理多个通知
Aug 17 Javascript
解决VUE项目使用Element-ui 下拉组件的验证失效问题
Nov 07 #Javascript
详解datagrid使用方法(重要)
Nov 06 #Javascript
VUE异步更新DOM - 用$nextTick解决DOM视图的问题
Nov 06 #Javascript
nuxt.js服务端渲染中axios和proxy代理的配置操作
Nov 06 #Javascript
微信小程序开发数据缓存基础知识辨析及运用实例详解
Nov 06 #Javascript
nuxt 路由、过渡特效、中间件的实现代码
Nov 06 #Javascript
Nuxt的路由动画效果案例
Nov 06 #Javascript
You might like
php+ajax实现仿百度查询下拉内容功能示例
2017/10/20 PHP
详解PHP多个进程配合redis的有序集合实现大文件去重
2019/03/06 PHP
laravel框架路由分组,中间件,命名空间,子域名,路由前缀实例分析
2020/02/18 PHP
Javascript 实用小技巧
2010/04/07 Javascript
JavaScript 通过模式匹配实现重载
2010/08/12 Javascript
基于JQuery实现的类似购物商城的购物车
2011/12/06 Javascript
CSS+jQuery实现的一个放大缩小动画效果
2013/09/24 Javascript
原生js ActiveXObject获取execl里面的值
2013/11/01 Javascript
JavaScript控制listbox列表框的项目上下移动的方法
2015/03/18 Javascript
Javascript 调用 ActionScript 的简单方法
2016/09/22 Javascript
Node.js与Sails redis组件的使用教程
2017/02/14 Javascript
JavaScript队列的应用实例详解【经典数据结构】
2017/04/12 Javascript
react中的ajax封装实例详解
2017/10/17 Javascript
vue实现微信分享朋友圈,发送朋友的示例讲解
2018/02/10 Javascript
创建echart多个联动的示例代码
2018/11/23 Javascript
详解微信小程序实现仿微信聊天界面(各种细节处理)
2019/02/17 Javascript
小程序调用微信支付的方法
2019/09/26 Javascript
js实现详情页放大镜效果
2020/10/28 Javascript
javascript实现电商放大镜效果
2020/11/23 Javascript
[03:04]DOTA2英雄基础教程 影魔
2013/12/11 DOTA
Python数组遍历的简单实现方法小结
2016/04/27 Python
用python标准库difflib比较两份文件的异同详解
2018/11/16 Python
python的xpath获取div标签内html内容,实现innerhtml功能的方法
2019/01/02 Python
python安装requests库的实例代码
2019/06/25 Python
python单线程下实现多个socket并发过程详解
2019/07/27 Python
Win10环境python3.7安装dlib模块趟过的坑
2019/08/01 Python
Python 通过截图匹配原图中的位置(opencv)实例
2019/08/27 Python
python+jinja2实现接口数据批量生成工具
2019/08/28 Python
python面向对象之类属性和类方法案例分析
2019/12/30 Python
flask框架url与重定向操作实例详解
2020/01/25 Python
python批量修改文件名的示例
2020/09/27 Python
python 使用xlsxwriter循环向excel中插入数据和图片的操作
2021/01/01 Python
创意活动策划书
2014/01/15 职场文书
体现团队精神的口号
2014/06/06 职场文书
大三学生英语考试作弊检讨书
2015/01/01 职场文书
行政人事主管岗位职责
2015/04/11 职场文书