首页 > 其他分享 >el-select实现下拉框触底加载更多

el-select实现下拉框触底加载更多

时间:2022-11-14 11:34:10浏览次数:40  
标签:el 自定义 指令 注册 下拉框 select

当下拉框需要展示的数据有很多时,几千甚至上万条,一次性全部请求回来再按照特定格式比如 id-name 去处理数据的话,不论是从接口还是前端,这个性能都不是很好,会造成下拉框初次打开时响应很慢,影响用户体验。

于是想给下拉框做一个类似分页请求的功能,目前使用的是element-ui,只有提供远程搜索功能,没有触底加载相关指令,所以准备写一个自定义指令。

 

Vue自定义指令简介:

除了核心功能默认内置的指令 (v-model 和 v-show),Vue 也允许注册自定义指令。注意,在 Vue2.0 中,代码复用和抽象的主要形式是组件。然而,有的情况下,你仍然需要对普通 DOM 元素进行底层操作,这时候就会用到自定义指令。

 

注册自定义指令的两种方式:全局注册和局部注册,两种方式我都会演示一遍

 

一、全局注册

 1 Vue.directive('loadmore', {
 2    inserted: function (el, binding) { 
 3        const dom = el.querySelector('.el-select-dropdown .el-select-dropdown__wrap'); // 获取下拉框元素
 5        dom.addEventListener('scroll', function () {   // 监听元素触底
 6           const condition = this.scrollHeight - this.scrollTop <= this.clientHeight;
 8           if (condition) {
 9             binding.value();
10           }
11        });
12    }
13 })

 

二、局部注册

 1 export default {
 2   directives: {  // 在组件中接受一个 directives 的选项
 3     loadmore: {
 4       inserted(el, binding) {
 5         const dom = el.querySelector('.el-select-dropdown .el-select-dropdown__wrap');  // 获取下拉框元素
 6         dom.addEventListener('scroll', function () {       // 监听元素触底
 7           const condition = this.scrollHeight - this.scrollTop <= this.clientHeight;
 8           if (condition) {
 9             binding.value();
10           }
11         });
12       },
13     },
14   },
15 }

 

使用方法:

不论全局注册还是局部注册之后,使用方式都是一样的,与v-model、v-if之类指令一致

<template>
  <el-select v-model="value" placeholder="请选择" v-loadmore="loadmore"> // 使用指令绑定事件
    <el-option
      v-for="item in options"
      :key="item.value"
      :label="item.label"
      :value="item.value">
    </el-option>
  </el-select>
</template>

<script>
export default {
    methods:{
        loadmore(){
          // 当下拉框滚动且触底时,会触发此事件,可以在此处去请求下拉框分页数据
        }
    }
}
</script>    

注:由于el-select有默认最大高度,所以第一页数据需要略微多几条,不然不会出现下拉框滚动条,也就触发不了触底事件。我看了下大概8条数据即可出滚动条

标签:el,自定义,指令,注册,下拉框,select
From: https://www.cnblogs.com/527xyz/p/16884225.html

相关文章

  • Android 使用TableLayout动态绘制表格
    第一步:在layout文件中添加TableLayout在layout文件中添加TableLayout组件,其中添加两行TableRow,绘制表格标题和表格列的名称。在需要分格的TableRow中添加LinearLayout,,......
  • dir help 以及类之间关系
    1,dir看对象或类的成员列表,比如函数和变量2,help看对象或类的使用方法3,对象或类之间关系:3.1,type().__name__3.2,type().__base__.__name__或者,classname.__base__.__name......
  • feig整合sentinel出现循环依赖问题
    feig整合sentinel出现循环依赖问题1.场景重现,回顾feign整合sentinel步骤1.1修改配置,开启sentinel功能修改OrderService的application.yml文件,开启Feign的Sentinel功能:f......
  • shell脚本测试配置寄存器数值·
    shell脚本测试同一寄存器下配置不同数值配置的测试##!/bin/shreg_value=0check_reg=`devmem0x10081000`while[$reg_value-lt252]do echo"CurrentTx_Reg_Valu......
  • layui(下拉框动态赋值,并根据要求默认选中下拉框)
    前言:layui虽然已经成为了过去式,还是那句话,江湖上虽然再也不见它的身影,但是依然流传着它的传说!(1)先做一个下拉框  (2)请求后端,获取需要填充的值我先说下完成的需求:就是......
  • [15-445]Hash tabels memo
    这一章大概是一个hashtables的科普。因为刚上课不久andy就说我们自己不会去实现一个这玩意儿。现在有非常优秀的方案,你应该去使用那个最好的方案,那个方案把其他方案都......
  • element Vue-表单删除按钮以及修改按钮的使用(附加dialog对话的使用)
    先上代码: <el-table-columnwidth="300"label="操作"><templateslot-scope="scope"><el-buttonclass="btn"size="mi......
  • CancellationTokenSource
     publicstaticvoidwork(CancellationTokencancellation){Thread.Sleep(10000);//while(true)//{Console.WriteLine("结束"+DateTime.N......
  • wheel for pesq error
      pip3install--upgradepip  sudoapt-getinstallpython3-dev......
  • C#中的ElementAt()方法
    https://www.nhooo.com/note/qa07nr.htmlElementAt()是C#中的System.Linq方法,用于获取和显示特定索引处的元素。以下是我们的字符串数组-string[] arr = { "One", ......