elementUI下拉选择select反应慢

在使用elementUI时,遇到select切换导致另一个下拉框响应慢的问题,原因是change事件触发大数据渲染。解决方法是利用v-show而非v-if控制显示,以减少DOM操作。对于多个数组的场景,寻求更优解决方案。
摘要由CSDN通过智能技术生成

最近遇到一个很诡异的问题,elementUI的select切换下拉选项,联动另一个下拉选项的选项数据时,变得很慢,改变选项后半天这个下拉框还不收起改变值,后面研究了一下,发现是change事件要执行完,下拉框才会收起改变值。但是我这个change事件要改变的是另一个下拉框选项数据,这个数据有特别大上千条,这个在渲染的dom的时候很慢,因此影响了第一个下拉框的改变响应。
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
后来想了一个办法,让数据渲染好,只是控制他的显示隐藏就好了,这个地方要注意不要用v-if v-else,要用v-show
vue中的 v-if 和 v-show 二者都可以动态的控制元素的隐藏和显示,但是他们控制的原理是不同的

v-if

v-if 控制元素显示或隐藏是把dom元素整个的渲染或者删除,如果删除,也就是页面中不存在这个dom元素,以此达到隐藏的效果;

所以v-if在每次切换的时候都会重新创建或者销毁元素,有较高的切换性能消耗;

而且v-if是惰性的,如

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值