基于elementui的远程搜索下拉选择分页组件

在开发一个练手项目的时候,需要一个远程搜索的下拉选择组件;
elementui自带的el-select支持远程搜索;但如果一次性查询的数据过多;会导致卡顿。故自己实现一个可分页的远程下拉选择组件
效果:
在这里插入图片描述
代码:

<template><el-selectv-model="selectedValue"filterableremotereserve-keywordplaceholder="请输入关键词":remote-method="remoteSearch":loading="loading"@change="handleChange"@focus="handleFocus"@clear="handleClear"clearable><el-optionv-for="item in options":key="item[keyField]":label="item[labelField]":value="item[valueField]"/><div class="select-footer" v-if="total > 0"><div class="total-count">{{ total }}</div><div class="select-pagination" v-if="total > pageSize"><el-paginationsmalllayout="prev, pager, next":total="total":page-size="pageSize":current-page.sync="currentPage"@current-change="handlePageChange"/></div></div></el-select>
</template><script>
import request from '@/utils/request'export default {name: 'RemoteSearchSelect',props: {value: {type: [String, Number],default: ''},apiUrl: {type: String,required: true},// 自定义字段映射labelField: {type: String,default: 'label'},valueField: {type: String,default: 'value'},keyField: {type: String,default: 'id'},// 请求参数自定义searchParamName: {type: String,default: 'keyword'},pageParamName: {type: String,default: 'pageNum'},pageSizeParamName: {type: String,default: 'pageSize'},// 响应数据结构配置responseListField: {type: String,default: 'list'},responseTotalField: {type: String,default: 'total'},// 额外的请求参数extraParams: {type: Object,default: () => ({})}},data() {return {selectedValue: this.value,options: [],loading: false,currentPage: 1,pageSize: 10,total: 0,keyword: '',isFirstFocus: true,selectedOption: null}},created() {this.remoteSearch('');},methods: {async remoteSearch(query) {this.loading = truethis.keyword = querytry {const params = {[this.searchParamName]: query,[this.pageParamName]: this.currentPage,[this.pageSizeParamName]: this.pageSize,...this.extraParams}// 使用配置的响应数据字段const responseData = await request({url: this.apiUrl,method: 'post',data: params})this.options = responseData[this.responseListField] || []this.total = responseData[this.responseTotalField] || 0} catch (error) {console.error('搜索出错:', error)this.$message.error('搜索失败,请重试')} finally {this.loading = false}},handleChange(value) {this.selectedOption = this.options.find(item => item[this.valueField] === value)this.$emit('input', value)this.$emit('change', value)this.$emit('select', this.selectedOption)},handleFocus() {// 如果是首次点击或当前没有选项,则执行搜索this.remoteSearch(this.keyword)this.isFirstFocus = false},handleClear() {this.selectedValue = ''this.keyword = ''this.selectedOption = nullthis.$emit('input', '')this.$emit('change', '')this.$emit('select', null)this.remoteSearch('')},async handlePageChange(page) {this.currentPage = pageif (this.keyword) {await this.remoteSearch(this.keyword)}}},watch: {value: {handler(newVal) {this.selectedValue = newVal},immediate: true}}
}
</script><style scoped>
.select-footer {padding: 8px;border-top: 1px solid #EBEEF5;display: flex;align-items: center;justify-content: space-between;
}.total-count {color: #909399;font-size: 12px;padding-left: 8px;
}:deep(.el-pagination) {padding: 0;margin-left: 8px;
}
</style>

用法

<remote-search-selectv-model="assignForm.ownerId"api-url="remoteUrl"label-field="label"value-field="value"key-field="id"search-param-name="childName"response-list-field="rows"response-total-field="total"@select="handleProxyerSelectChange"/>

参数介绍:

参数说明
v-model绑定的data数据
api-url远程查询的数据接口路径,方法名,请求方式为post
label-field需要展示的名称属性名
value-field下拉值的属性名
key-field主键的属性名
search-param-name模糊搜索的参数的字段名
response-list-field返回list的属性名
response-total-field返回list的总数的属性名
@selectfuntion,接收选中的值

组件可根据自己的具体需求做源码修改。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/888710.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

告别充电焦虑:移动充电机器人的革命性解决方案

移动充电机器人作为新能源汽车领域的黑科技&#xff0c;正逐渐崭露头角。它的出现为电动汽车充电带来了全新的解决方案&#xff0c;解决了传统充电方式的诸多痛点。 新能源汽车具有诸多优点&#xff0c;如科技含量高、噪音小、使用成本低等&#xff0c;但 “续航焦虑”“充电焦…

Socket 编程预备

目录 理解源 IP 地址和目的 IP 地址 认识端口号 端口号范围划分 理解 "端口号" 和 "进程 ID" 理解源端口号和目的端口号 理解 socket 传输层的典型代表 认识 TCP 协议 认识 UDP 协议 网络字节序 socket 编程接口 socket 常见 API sock…

17. Threejs案例-Three.js创建多个立方体

17. Threejs案例-Three.js创建多个立方体 实现效果 知识点 WebGLRenderer (WebGL渲染器) WebGLRenderer 是 Three.js 中用于渲染 WebGL 场景的核心类。它负责将场景中的对象渲染到画布上。 构造器 new THREE.WebGLRenderer(parameters) 参数类型描述parametersObject可选…

实例教程:BBDB为AHRS算法开发提供完善的支撑环境(下)

4. BBDB基础上为算法实现提供支撑方式二&#xff1a;算法层实现 第2节内容当中讲述在应用层实现AHRS的步骤&#xff0c;这种方法优点在于实现方法比较简单明了。但是缺点在于程序代码的组织算不上很好&#xff0c;AHRS算法代码与PH47框架代码间存在一定的耦合度&#xff0c;会…

数字证书实现oauth2.0与token去中心化的解耦

鉴权服务oauth2.0的既要还要的痛点 鉴权服务手撸&#xff1f;不可能&#xff0c;上spring security&#xff01; 感觉还不够&#xff1f;再叠加oauth2.0&#xff01; 鉴权太重&#xff1f;换用分布式token&#xff01; 既然分布式了&#xff0c;是不是可以不用鉴权中心&#xf…

鸿蒙Next学习-监听指定页面显示/页面生命周期

自定义组件监听页面生命周期 使用无感监听页面路由的能力&#xff0c;能够实现在自定义组件中监听页面的生命周期。 // Index.ets import { uiObserver, router, UIObserver } from kit.ArkUI;Entry Component struct Index {listener: (info: uiObserver.RouterPageInfo) &g…

wordpress收录好好的换了个模板就突然不收录了

wordpress收录好好的换了个模板就突然不收录了&#xff0c;而且原来收录的也给删除了&#xff0c;是模板的问题吗? 一般来说&#xff0c;不是模板的问题&#xff0c;是突然换模板&#xff0c;或添加大量内容、导致数据结构等方面变化&#xff0c;被搜索引擎当作弊的处罚了。要…

solon 集成 kafka-clients

使用 kafka-clients 原本是比较简单的事情。但有些同学习惯了 spring-kafka 后&#xff0c;对原始 java 接口会陌生些。会希望有个集成的示例。 <dependency><groupId>org.apache.kafka</groupId><artifactId>kafka-clients</artifactId><ve…

Android开发,使用ViewPager2实现自动轮播图

文章目录 1. build.gradle添加依赖&#xff1a;2. AndroidManifest.xml中添加网络访问权限3. 编写 布局文件4. 编写Banner适配器5. 自定义Banner视图6. 定义圆点指示器的drawable资源7. 在需要使用轮播图中的Activity中使用8. 运行效果图9. 视频教程 在Android项目程序设计中&a…

Oracle DataGuard启动与关闭顺序

在Oracle Data Guard环境中&#xff0c;启动和关闭数据库的顺序非常重要&#xff0c;以确保数据的一致性和最小化服务中断。以下是针对主库&#xff08;Primary Database&#xff09;和备库&#xff08;Standby Database&#xff09;启动与关闭的标准步骤。 启动顺序 1. 启动…

JavaScript 中基元类型与引用类型的解析

文章目录 基元类型Undefined 类型Null 类型Boolean 类型Number 类型String 类型Symbol 类型 类型详解对象&#xff08;Object&#xff09;数组&#xff08;Array&#xff09;函数&#xff08;Function&#xff09;日期&#xff08;Date&#xff09;、正则表达式&#xff08;Reg…

切比雪夫不等式:方差约束下的概率估计

切比雪夫不等式&#xff1a;方差约束下的概率估计 背景 在概率分析中&#xff0c;切比雪夫不等式是一个常用的工具&#xff0c;它通过引入随机变量的 方差信息&#xff0c;给出了偏离均值的概率界限。这一不等式是对 马尔科夫不等式 的自然扩展&#xff0c;结合了更丰富的分布…

企业网双核心交换机实现冗余和负载均衡(MSTP+VRRP)

MSTP&#xff08;多生成树协议&#xff09; 通过创建多个VLAN实例&#xff0c;将原有的STP、RSTP升级&#xff0c;避免单一VLAN阻塞后导致带宽的浪费&#xff0c;通过将VLAN数据与实例绑定&#xff0c;有效提升网络速率。 VRRP&#xff08;虚拟路由冗余协议&#xff09; 用…

Socket编程-tcp

1. 前言 在tcp套接字编程这里&#xff0c;我们将完成两份代码&#xff0c;一份是基于tcp实现普通的对话&#xff0c;另一份加上业务&#xff0c;client输入要执行的命令&#xff0c;server将执行结果返回给client 2. tcp_echo_server 与udp类似&#xff0c;前两步&#xff1…

深入浅出云计算 ---笔记

这是博主工作闲时的一些日常学习记录&#xff0c;有些之前很熟悉的&#xff0c;但工作中不常用&#xff0c;慢慢就遗忘了&#xff0c;在这里记录&#xff0c;也是为了激励自己坚持复习&#xff0c;如果有能帮到你&#xff0c;那我将感到非常的荣幸~ 快速到达↓↓↓ IaaS篇>&…

14 设计模式值观察者模式(书籍发布通知案例)

一、观察者模式定义 在日常开发中&#xff0c;我们经常会遇到一种场景&#xff1a;某个对象的状态发生变化时&#xff0c;需要通知并更新其他相关对象。这时&#xff0c;观察者模式便成为了解决问题的有效方案。观察者模式是一种常见的设计模式&#xff0c;它允许一个对象的状态…

15分钟训练数字人MimicTalk

只需15分钟&#xff0c;就能训练高质量&#xff0c;个性化数字人大模型。由浙江大学与字节跳动联合推出MimicTalk算法&#xff0c;目前已开源。 在外表和说话风格上和真人相似。将通用3D数字人大模型适应到单个目标人&#xff0c;采用动静结合的高效微调方案&#xff0…

c++高级篇(四) ——Linux下IO多路复用之epoll模型

IO多路复用 —— epoll 前言 在之前我们就已经介绍过了select和poll,在作为io多路复用的最后一个的epoll,我们来总结一下它们之间的区别: a select 实现原理 select 通过一个文件描述符集合&#xff08;fd_set&#xff09;来工作&#xff0c;该集合可以包含需要监控的文件…

【kettle】mysql数据抽取至kafka/消费kafka数据存入mysql

目录 一、mysql数据抽取至kafka1、表输入2、json output3、kafka producer4、启动转换&#xff0c;查看是否可以消费 二、消费kafka数据存入mysql1、Kafka consumer2、Get records from stream3、字段选择4、JSON input5、表输出 一、mysql数据抽取至kafka 1、表输入 点击新建…

docker-compose部署skywalking 8.1.0

一、下载镜像 #注意 skywalking-oap-server和skywalking java agent版本强关联&#xff0c;版本需要保持一致性 docker pull elasticsearch:7.9.0 docker pull apache/skywalking-oap-server:8.1.0-es7 docker pull apache/skywalking-ui:8.1.0二、部署文件docker-compose.yam…