前端vue框架select下拉数据量过大造成卡顿问题解决办法

 更新时间:2023年07月27日 09:09:33   作者:youngOwl  
这篇文章主要给大家介绍了关于前端vue框架select下拉数据量过大造成卡顿问题解决办法,文中通过示例代码介绍的非常详细,对大家学习或者使用select具有一定的参考借鉴价值,需要的朋友可以参考下

问题:

当加载上百条、上千条数据,导致下拉框数据卡顿

解决:

将数据分割成更小的单元,每次下拉到底部加载一部分

 利用下拉滚动事件

视图部分:

<a-select label-in-value :default-value="{ key: 'lucy' }" style="width: 120px" @change="handleChange" @popupScroll="handldpopupscroll" ><a-select-option></a-select-option></a-select>

逻辑处理:

//每次滚动触发
handldpopupscroll(e){
//向下滚动时,判断e.target.scrollHeight(实际下拉列表高度)-e.target.clientHeight(可视框高度)==e.target.scrollTop(卷起的高度)
if(e.target.scrollHeight-e.target.clientHeight==e.target.scrollTop){
//(指向下一个分组数据)
this.scrollPage++
//第一个位置=当前分组数据*每组数据的数量
let beforts=this.scrollNumber*(this.scrollPage-1)
//第二个位置=下一个分组指向*每组数据的数量-1
let afters=this.scrollNumber*this.scrollPage-1
展示数组=原数组.slice(第一个位置,第二个位置)
//(使滑块位置不置于最上面,才能向上滑动)
e.target.scrollTop=5
//为了防止滑块滑动太快将以上加在延时器里面,不然数据会跳
}
//向上滚动时,判断e.target.scrollTop(卷起的高度小于1)和this.scroPage指向下一个分组数据的角标大于1
if(target.scrollTop<1&&this.scroPage>1){
//(指向上一个分组数据)
this.scrollPage--
//第一个位置=当前分组数据*每组数据的数量
let beforts=this.scrollNumber*(this.scrollPage-1)
//第二个位置=下一个分组指向*每组数据的数量-1
let afters=this.scrollNumber*this.scrollPage-1
展示数组=原数组.slice(第一个位置,第二个位置)
//判断是否是第一组数据
if(this.scrollPage!=1){
//(使滑块位置不置于最上面,才能向上滑动)
e.target.scrollTop=5
}
//为了防止滑块滑动太快将以上加在延时器里面,不然数据会跳
}
}

总结 

到此这篇关于前端vue框架select下拉数据量过大造成卡顿问题解决办法的文章就介绍到这了,更多相关vue select下拉数据量过大卡顿内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • vue element-ui el-tooltip组件失效问题及解决

    vue element-ui el-tooltip组件失效问题及解决

    这篇文章主要介绍了vue element-ui el-tooltip组件失效问题及解决方案,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-10-10
  • 详解vue 组件的实现原理

    详解vue 组件的实现原理

    这篇文章主要介绍了详解vue 组件的实现原理,帮助大家更好的理解和学习vue框架,感兴趣的朋友可以了解下
    2020-11-11
  • 使用vue2实现带地区编号和名称的省市县三级联动效果

    使用vue2实现带地区编号和名称的省市县三级联动效果

    我们知道省市区县都有名称和对应的数字唯一编号,使用编号可以更方便查询以及程序处理,我们今天来了解一下使用vue2来实现常见的省市区下拉联动选择效果,需要的朋友可以参考下
    2018-11-11
  • 浅析vue深复制

    浅析vue深复制

    这篇文章主要介绍了vue深复制的相关资料,非常不错,具有参考借鉴价值,需要的朋友参考下
    2018-01-01
  • vue-element-admin如何设置默认语言

    vue-element-admin如何设置默认语言

    这篇文章主要介绍了vue-element-admin如何设置默认语言,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-04-04
  • 详解Vue3 中的watchEffect 特性

    详解Vue3 中的watchEffect 特性

    这篇文章主要介绍了Vue3 中的 watchEffect 特性详解,watchEffect 是 Vue3 中非常有用的一个特性,它可以让我们轻松地监听响应式数据的变化,并在数据发生变化时执行指定的回调函数,从而简化代码并提高应用的性能,需要的朋友可以参考下
    2023-04-04
  • vue项目中播放rtmp视频文件流的方法

    vue项目中播放rtmp视频文件流的方法

    这篇文章主要介绍了vue项目中播放rtmp视频文件流 ,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-09-09
  • 关于ElementUI el-table 鼠标滚动失灵的问题及解决办法

    关于ElementUI el-table 鼠标滚动失灵的问题及解决办法

    这篇文章主要介绍了关于ElementUI el-table 鼠标滚动失灵的问题及解决办法,本文给大家分享问题所在原因及解决方案,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2023-08-08
  • Vue3实现计算属性的代码详解

    Vue3实现计算属性的代码详解

    计算属性对于前端开发来说算是经常使用的一个能力了,本文将从代码层面来给大家介绍下Vue3是如何实现计算属性的,需要的朋友可以参考下
    2023-07-07
  • 关于elementUI select控件绑定多个值(对象)

    关于elementUI select控件绑定多个值(对象)

    这篇文章主要介绍了关于elementUI select控件绑定多个值(对象),具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-04-04

最新评论