element ui el-select组件添加选项下拉加载

需求描述:在做搜索的时候由于有一个下拉列表接口返回数据特别多所以对列表进行了一个下拉触底加载的事件,但是官方文档是没有对应的api的所以自己使用指令写了一个方法。

实现代码:

javascript 复制代码
        <el-select
          v-model="sellerNameSearchVal"
          v-select-loadmore="loadmore"
          remote
          filterable
          placeholder="请输入要搜索的供应商名称"
          class="w100"
          clearable
          :remote-method="selectSearch"
          @visible-change="selectVisibleChange"
          @change="onSellerNameChange"
          @clear="onSellerNameClear"
          @keyup.native.enter="onSellerNameEnter"
        >
          <el-option
            v-for="(item,index) in supplierList"
            :key="index"
            :label="item.label"
            :value="item.value"
          />
          <!-- 分页状态 -->
          <el-option disabled style="height: 25px;" class="flex flex-center">
            <div v-show="selectLoading">
              <i class="el-icon-loading mr10" />
              <span>正在加载更多...</span>
            </div>

            <div v-show="supplierList.length <= 0 && !selectLoading">无匹配数据</div>

            <div v-if="supplierList.length > 0 && supplierLeave <= 0">没有更多了</div>
          </el-option>
        </el-select>

关键点在于v-select-loadmore="loadmore"这个自定义指令

javascript 复制代码
  directives: {
    'select-loadmore': {
      bind(el, binding) {
        const element = el.querySelector('.el-select-dropdown .el-select-dropdown__wrap')
        element.addEventListener('scroll', function(e) {
          // this.scrollTop 存在小数,导致加减存在1的误差
          const condition = Math.abs(this.scrollHeight - this.scrollTop - this.clientHeight) <= 1
          if (condition) binding?.value()
        })
      }
    }
  },

这个指令的逻辑是监听元素的滚动事件,当滚动高度达到select的高度后调用loadmore这个方法去加载下一页的数据

相关推荐
爬虫练习生1 分钟前
极验4ast解混淆流程
javascript
踩着两条虫9 分钟前
AI + 低代码实战 | 一文吃透 API 管理、Swagger 导入与全局配置
前端·低代码·ai编程
AI自动化工坊9 分钟前
T3 Code:专为AI编程代理设计的Web IDE技术实践指南
前端·ide·人工智能·ai编程·t3
梦梦代码精14 分钟前
LikeShop 深度测评:开源电商的务实之选
java·前端·数据库·后端·云原生·小程序·php
Mr.E515 分钟前
odoo18 关闭搜索框点击自动弹出下拉框
开发语言·前端·javascript·odoo·owl·odoo18
鹏程十八少17 分钟前
4. 2026金三银四 Android OkHttp 面试核心 45 问:从源码到架构深度解析
android·前端·面试
invicinble19 分钟前
前端技术栈--webpack
前端·webpack·node.js
天籁晴空22 分钟前
微信小程序 静默登录 + 授权登录 双模式配合的设计方案
前端·微信小程序·uni-app
|晴 天|24 分钟前
Vue 3 博客 SEO 优化:Meta 标签、Sitemap、Schema.org 实战
前端·vue.js·dreamweaver
Apple_羊先森25 分钟前
# MOSS-TTS-Nano 教程 02:CLI 与 Web Demo 实战
前端·人工智能