ElementPlus 穿梭框支持批量穿梭

按照目前的方案试了**el-virtual-transfer**: ,这个库对于vue3+ts的代码无效。

方案:魔改原生的transfer组件,把原来的el-checkbox包一层虚拟滚动列表

废话不多说:实现的效果如下:

批量勾选3000个设备到左边做到不卡顿

关键代码:

复制代码
      <ElCheckboxGroup
        v-show="!hasNoMatch && data.length > 0"
        v-model="checked"
        :class="{ 'is-filterable': filterable }"
        class="el-transfer-panel__list"
        style="display: flex; flex-direction: column; height: 100%; overflow: hidden"
      >
        <VirtualList
          v-if="virtualScroll && filteredData.length > 0"
          style="flex: 1; height: 400px; overflow-y: auto"
          :data-key="propsAlias.key"
          :data-sources="filteredData"
          :data-component="TransferCheckboxItem"
          :estimate-size="40"
        />
        <template v-else>
          <ElCheckbox
            v-for="item in filteredData"
            :key="item[propsAlias.key]"
            :class="ns.be('panel', 'item')"
            :value="item[propsAlias.key]"
            :disabled="item[propsAlias.disabled]"
            :validate-event="false"
          >
            <OptionContent :option="optionRender?.(item)" />
          </ElCheckbox>
        </template>
      </ElCheckboxGroup>


import VirtualList from "vue3-virtual-scroll-list";

<customTransfer
        ref="transferRef"
        v-model="selectedDeviceKeys"
        :data="transferData"
        filterable
        :filter-method="filterMethod"
        filter-placeholder="请输入关键字进行模糊搜索"
        :titles="transferTitles"
        :button-texts="['解绑', '绑定']"
        class="full-height-transfer"
        :virtual-scroll="true"
/>

项目地址:https://github.com/EmilyHOC/el-transfer-pannel-bigData/tree/main

相关推荐
掘金安东尼19 小时前
⏰前端周刊第 458 期v2026.3.24
前端·javascript·面试
前端付豪20 小时前
实现必要的流式输出(Streaming)
前端·后端·agent
张元清20 小时前
useMediaQuery:React 响应式设计完全指南
前端·javascript·面试
小金鱼Y20 小时前
一文吃透 JavaScript 防抖:从原理到实战,让你的页面不再 “手抖”
前端·javascript·面试
Z兽兽20 小时前
React 18 开发环境下useEffect 会执行两次,原因分析及解决方案
前端·react.js·前端框架
紫_龙20 小时前
最新版vue3+TypeScript开发入门到实战教程之Vue3详解props
前端·vue.js·typescript
树上有只程序猿20 小时前
这波低代码热,能维持多久
前端
姓王名礼20 小时前
这是一个完整的全栈交付包,包含Vue3 前端交互界面(集成数字人视频流、ECharts 图表、语音对话)和Docker Compose 一键部署脚本。
前端·docker·echarts
嵌入式-老费20 小时前
vivado hls的应用(axis接口)
前端·webpack·node.js
孟陬20 小时前
国外技术周刊第 2 期 — 本周热门 🔥 YouTube 视频 TED 演讲 AI 如何能够拯救(而非摧毁)教育
前端·后端·程序员