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
         })
     })
相关推荐
IT教程资源D2 小时前
[N_144]基于微信小程序在线订餐系统
mysql·vue·uniapp·前后端分离·订餐小程序·springboot订餐
是梦终空2 天前
vue下载依赖报错npm ERR node-sass@4.14.1 postinstall: `node scripts/build.js`的解决方法
javascript·npm·vue·node-sass·vue依赖
陈陈小白2 天前
npm run dev报错Error: listen EADDRINUSE: address already in use :::8090
前端·npm·node.js·vue
韩立学长2 天前
【开题答辩实录分享】以《证劵数据可视化分析项目设计与实现》为例进行答辩实录分享
python·信息可视化·vue
二当家的素材网2 天前
【无标题】
vue·uniapp
合作小小程序员小小店2 天前
web网页开发,在线%考试管理%系统,基于Idea,vscode,html,css,vue,java,maven,springboot,mysql
java·前端·系统架构·vue·intellij-idea·springboot
.NET快速开发框架3 天前
国思RDIF低代码快速开发框架 v6.2.2版本发布
低代码·vue·rdif·国思rdif开发框架
IT教程资源D3 天前
[N_148]基于微信小程序网上书城系统
mysql·vue·uniapp·前后端分离·网上书城小程序·springboot书城
摇滚侠3 天前
Vue 项目实战《尚医通》,底部组件拆分与静态搭建,笔记05
前端·vue.js·笔记·vue
键盘飞行员4 天前
Vue3+TypeScript项目中配置自动导入功能,遇到了问题需要详细的配置教程!
前端·typescript·vue