iview select组件在大数据情况下虚拟加载处理方式

select 组件在几千上万条数据的时候特别卡,调试发现option组件渲染太多,导致整个页面都卡,通过调研发现可以通过虚拟加载的方式动态渲染option,亲测上万数据一点都不卡,废话不说,上代码

虚拟加载用的是 vue-virtual-scroller 具体怎么安装和使用,这就不介绍,网上一大把,下面是select结合 vue-virtual-scroller 的代码,由于option上包了一成代码,会导致select选中的样式不会自动加上,需要手动在option上加上选中样式

html 复制代码
 <Select v-model="nodeData.fileUniqueList" multiple filterable filter-by-label
          ref="select"
          @on-query-change="fileQueryChange"
          style="width:100%">
          <recycle-scroller
            class="virtual-list"
            :buffer="200"
            :prerender="10"
            style="height: 180px"
            :item-size="30"
            key-field="value"
            :items="fileList">
            <template v-slot="{ item, index }">
              <Option
                :class="{'ivu-select-item selected':nodeData.fileUniqueList.includes(item.value)}"
                :value="item.value" :key="item.value" :label="item.fileName">{{ item.fileName }}
              </Option>
            </template>
          </recycle-scroller>
        </Select>

在 mounted 中把select的自动过滤方法重写,这一步很关键,没这一步会导致搜索的option被强制重写,这样永远都渲染不出来数据

javascript 复制代码
 this.$nextTick(() => {
      // 替换过滤函数
      this.$refs.select.validateOption = () => true;
    });

然后就是自定义查询方法,通过 on-query-change事件自己写过滤方法,我这是先把查出来的数据备份了一份,然后在备份的数据里面查找在深度拷贝给对象

javascript 复制代码
fileQueryChange(v) {
      if (v) {
        let data = deepClone(this.fileListBak.filter(f => f.fileName.indexOf(v) >= 0))
        this.fileList = data
      } else {
        this.fileList = deepClone(this.fileListBak)
      }
    },

最后就是返现问题,由于动态渲染不会把所有的option都渲染出来,导致不能返现,调试了下发现多选的时候,select组件是在values里面plus值,所以在数据返回后,循环以前选中的,然后查找,最后给values赋值,这是多选的方式,单选应该也是大同小异,如果不行,去调试一下看单选是怎么赋值的

javascript 复制代码
    this.$refs.select.values = []
    this.nodeData.fileUniqueList.forEach(f => {
         let data = this.fileList.find(d => d.value == f)
         this.$refs.select.values.push({
            label: data.fileName,
            tag: undefined,
            value: f
         })
     })
相关推荐
来杯@Java12 小时前
学生选课管理系统(基于springboot+vue前后端分离的项目)计算机毕业设计java
java·spring boot·spring·vue·毕业设计·maven·mybatis
医疗信息化王工20 小时前
医院自律端系统——预警处置模块全栈实战(ASP.NET Core + Vue3 + Quartz 定时调度)
mysql·postgresql·vue·asp.net core·quartz
大大杰哥1 天前
Vue2学习(1)--了解基本方法与概念
javascript·学习·vue
Agatha方艺璇2 天前
前端开发技术复习笔记
vue·bootstrap·css3·html5·web
小葛要努力2 天前
创建vue2项目
程序人生·vue
七仔啊2 天前
基于海康门禁的人员计数系统
vue
步十人3 天前
【Vue3】前置知识简单概述(包括ES6核心语法,模块化ESM以及npm基础)
arcgis·npm·vue·es6
有梦想的程序星空4 天前
【环境配置】Vue3项目离线化本地部署echarts全攻略
前端·javascript·vue·echarts
向日的葵0064 天前
vue路由(二)
前端·javascript·vue.js·vue
小妖6665 天前
Hydration completed but contains mismatches
javascript·vue·vuepress