实现el-select的远程搜索,并且展示最近搜索的十条数据

2024-01-29 19:40

本文主要是介绍实现el-select的远程搜索,并且展示最近搜索的十条数据,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

项目场景:

使用el-select实现远程搜索,并且可以输入进行搜索,首次点击的时候显示十条历史记录,在输入之后就展示远程搜索返回的数据


问题描述

1、el-select的远程搜索如果实现

2、怎么记录历史搜索的数据

3、如果实现输入之后点击回车就进入到结果页面


问题分析:

远程搜索的实现

远程搜索的实现,el-select组件中有远程搜索的API

 <el-selectpopper-class="social-economy-search-input"v-model="keywords"placeholder="请输入关键词"filterableremote:remote-method="remoteMethod":loading="loadingOption"@click="getHistorySearch"@change="handleChange"@keyup.enter="keyupEnter">

remote:其中的选项是否从服务器远程加载

remote-method:自定义远程搜索方法

loading:是否正在从远程获取数据

利用remote-method这个API自定义远程搜索的方法,当进行远程搜索的时候就开启loading,有数据结束之后就关闭loading

这里我为什么要定义这三个方法呢?

@click="getHistorySearch"  ,点击select选择器的时候,获取历史记录
@change="handleChange",当select选择器的数据发生变化的时候触发
@keyup.enter="keyupEnter",当回车的时候触发

//远程搜索
const remoteMethod = async (val) => {if (val) {loadingOption.value = true;keywords.value = val;let params = {keywords: keywords.value,pageSize: pageSize.value,};let res = await httpPost("economicStatistics/v1/searchIndicatorListByKeywords",params);if (res.code == 0) {options.value.label = "";options.value.list = res.data;loadingOption.value = false;} else {loadingOption.value = false;}} else {keywords.value = "";loadingOption.value = false;}
};

 历史记录的实现

要实现历史记录就要记录用户输入后请求的每一次数据,将用户的输入存储localStorage中,在用户点击select的时候,展示最近十条历史记录

注意:获取最近十条历史记录,当用户有输入与之前记录相同的关键字,就删除掉之前的记录只展示最新的相同的记录

//历史记录列表
const historySearchKeyWordsList = ref([]);
//删除历史搜索中与当前输入相同的关键字
const removeDuplicate = () => {historySearchKeyWordsList.value =JSON.parse(localStorage.getItem("keywords")) || [];const index = historySearchKeyWordsList.value.indexOf(keywords.value); // 查找新元素在数组中的索引if (index !== -1) {historySearchKeyWordsList.value.splice(index, 1); // 删除数组中与新元素相同的旧元素}return historySearchKeyWordsList.value;
};
//存储历史搜索关键字
const saveKeyWords = () => {if (historySearchKeyWordsList.value.length >= 10) {historySearchKeyWordsList.value.pop(); // 删除最早存储的关键字}historySearchKeyWordsList.value.unshift(keywords.value);localStorage.setItem("keywords",JSON.stringify(historySearchKeyWordsList.value));
};
//获取历史搜索
const getHistorySearch = () => {const keywords = JSON.parse(localStorage.getItem("keywords")) || [];options.value.label = "历史搜索";options.value.list = keywords.map((item) => {return { name: item };});
};

解决方案:

<template><div class="database-index"><div class="social-economy"><div class="social-economy-logo"><imgsrc="@/assets/imgs/database/social-economy/socialEconomy-logo.png"alt=""/></div><div class="social-economy-search"><el-selectpopper-class="social-economy-search-input"v-model="keywords"placeholder="请输入关键词"filterableremote:remote-method="remoteMethod":loading="loadingOption"@click="getHistorySearch"@change="handleChange"@keyup.enter="keyupEnter"><template #prefix><el-icon class="el-input__icon"><search /></el-icon></template><el-option-group :key="options.label" :label="options.label"><el-optionv-for="item in options.list":key="item.name":label="item.name":value="item.name"><divclass="option-list"@click="getCurrentId(item.indicatorUniqueId)"><el-icon class="el-input__icon"><search /></el-icon><spanstyle="padding-left: 8px"v-html="highlightKeywords(item.name, keywords)"></span></div></el-option></el-option-group></el-select></div><div class="social-economy-list"></div></div></div>
</template><script setup>
import { ref } from "vue";
import { httpPost } from "@/api/httpService.js";import { useRoute, useRouter } from "vue-router";
import { highlightKeywords } from "@/utils/highlightKeywords.js";
import { Debounce } from "@/utils/utils";
import { ElMessage } from "element-plus";const route = useRoute();
const router = useRouter();
const loadingOption = ref(false); //是否正在加载选项数据
const options = ref({ label: "", list: [] });
const keywords = ref("");
const pageNum = ref(1);
const pageSize = ref(10);
const currentId = ref("");
//获取远程搜索点击时当前指标id
const getCurrentId = (id) => {currentId.value = id;
};
//远程搜索
const remoteMethod = async (val) => {if (val) {loadingOption.value = true;keywords.value = val;let params = {keywords: keywords.value,pageSize: pageSize.value,};let res = await httpPost("economicStatistics/v1/searchIndicatorListByKeywords",params);if (res.code == 0) {options.value.label = "";options.value.list = res.data;loadingOption.value = false;} else {loadingOption.value = false;}} else {keywords.value = "";loadingOption.value = false;}
};
//前往搜索结果页
const goSearchResult = () => {if (keywords.value && keywords.value !== "") {router.push({path: "/database/social-economy/search-result",query: {keywords: keywords.value,},});removeDuplicate();saveKeyWords();} else {ElMessage.warning("请输入搜索关键字!");}
};
const handleChange = async (value) => {keywords.value = value != null && value != "" ? value : "";if (options.value.label) {goSearchResult();} else {await saveSearchKeyWords();router.push({path: "/database/social-economy/indicator-result",query: {type: 3,id: currentId.value,},});}
};
const keyupEnter = () => {goSearchResult();
};
//历史记录列表
const historySearchKeyWordsList = ref([]);
//删除历史搜索中与当前输入相同的关键字
const removeDuplicate = () => {historySearchKeyWordsList.value =JSON.parse(localStorage.getItem("keywords")) || [];const index = historySearchKeyWordsList.value.indexOf(keywords.value); // 查找新元素在数组中的索引if (index !== -1) {historySearchKeyWordsList.value.splice(index, 1); // 删除数组中与新元素相同的旧元素}return historySearchKeyWordsList.value;
};
//存储历史搜索关键字
const saveKeyWords = () => {if (historySearchKeyWordsList.value.length >= 10) {historySearchKeyWordsList.value.pop(); // 删除最早存储的关键字}historySearchKeyWordsList.value.unshift(keywords.value);localStorage.setItem("keywords",JSON.stringify(historySearchKeyWordsList.value));
};
//获取历史搜索
const getHistorySearch = () => {const keywords = JSON.parse(localStorage.getItem("keywords")) || [];options.value.label = "历史搜索";options.value.list = keywords.map((item) => {return { name: item };});
};
//保存远程搜索关键字
const saveSearchKeyWords = async () => {let params = {keywords: keywords.value,};httpPost("economicStatistics/v1/saveSearchKeywords", params);
};
</script>

这篇关于实现el-select的远程搜索,并且展示最近搜索的十条数据的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/657978

相关文章

Oracle查询优化之高效实现仅查询前10条记录的方法与实践

《Oracle查询优化之高效实现仅查询前10条记录的方法与实践》:本文主要介绍Oracle查询优化之高效实现仅查询前10条记录的相关资料,包括使用ROWNUM、ROW_NUMBER()函数、FET... 目录1. 使用 ROWNUM 查询2. 使用 ROW_NUMBER() 函数3. 使用 FETCH FI

Python脚本实现自动删除C盘临时文件夹

《Python脚本实现自动删除C盘临时文件夹》在日常使用电脑的过程中,临时文件夹往往会积累大量的无用数据,占用宝贵的磁盘空间,下面我们就来看看Python如何通过脚本实现自动删除C盘临时文件夹吧... 目录一、准备工作二、python脚本编写三、脚本解析四、运行脚本五、案例演示六、注意事项七、总结在日常使用

Java实现Excel与HTML互转

《Java实现Excel与HTML互转》Excel是一种电子表格格式,而HTM则是一种用于创建网页的标记语言,虽然两者在用途上存在差异,但有时我们需要将数据从一种格式转换为另一种格式,下面我们就来看看... Excel是一种电子表格格式,广泛用于数据处理和分析,而HTM则是一种用于创建网页的标记语言。虽然两

Java中Springboot集成Kafka实现消息发送和接收功能

《Java中Springboot集成Kafka实现消息发送和接收功能》Kafka是一个高吞吐量的分布式发布-订阅消息系统,主要用于处理大规模数据流,它由生产者、消费者、主题、分区和代理等组件构成,Ka... 目录一、Kafka 简介二、Kafka 功能三、POM依赖四、配置文件五、生产者六、消费者一、Kaf

Python将大量遥感数据的值缩放指定倍数的方法(推荐)

《Python将大量遥感数据的值缩放指定倍数的方法(推荐)》本文介绍基于Python中的gdal模块,批量读取大量多波段遥感影像文件,分别对各波段数据加以数值处理,并将所得处理后数据保存为新的遥感影像... 本文介绍基于python中的gdal模块,批量读取大量多波段遥感影像文件,分别对各波段数据加以数值处

使用MongoDB进行数据存储的操作流程

《使用MongoDB进行数据存储的操作流程》在现代应用开发中,数据存储是一个至关重要的部分,随着数据量的增大和复杂性的增加,传统的关系型数据库有时难以应对高并发和大数据量的处理需求,MongoDB作为... 目录什么是MongoDB?MongoDB的优势使用MongoDB进行数据存储1. 安装MongoDB

使用Python实现在Word中添加或删除超链接

《使用Python实现在Word中添加或删除超链接》在Word文档中,超链接是一种将文本或图像连接到其他文档、网页或同一文档中不同部分的功能,本文将为大家介绍一下Python如何实现在Word中添加或... 在Word文档中,超链接是一种将文本或图像连接到其他文档、网页或同一文档中不同部分的功能。通过添加超

windos server2022里的DFS配置的实现

《windosserver2022里的DFS配置的实现》DFS是WindowsServer操作系统提供的一种功能,用于在多台服务器上集中管理共享文件夹和文件的分布式存储解决方案,本文就来介绍一下wi... 目录什么是DFS?优势:应用场景:DFS配置步骤什么是DFS?DFS指的是分布式文件系统(Distr

NFS实现多服务器文件的共享的方法步骤

《NFS实现多服务器文件的共享的方法步骤》NFS允许网络中的计算机之间共享资源,客户端可以透明地读写远端NFS服务器上的文件,本文就来介绍一下NFS实现多服务器文件的共享的方法步骤,感兴趣的可以了解一... 目录一、简介二、部署1、准备1、服务端和客户端:安装nfs-utils2、服务端:创建共享目录3、服

Python MySQL如何通过Binlog获取变更记录恢复数据

《PythonMySQL如何通过Binlog获取变更记录恢复数据》本文介绍了如何使用Python和pymysqlreplication库通过MySQL的二进制日志(Binlog)获取数据库的变更记录... 目录python mysql通过Binlog获取变更记录恢复数据1.安装pymysqlreplicat