实现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

相关文章

Flutter实现文字镂空效果的详细步骤

《Flutter实现文字镂空效果的详细步骤》:本文主要介绍如何使用Flutter实现文字镂空效果,包括创建基础应用结构、实现自定义绘制器、构建UI界面以及实现颜色选择按钮等步骤,并详细解析了混合模... 目录引言实现原理开始实现步骤1:创建基础应用结构步骤2:创建主屏幕步骤3:实现自定义绘制器步骤4:构建U

SpringBoot中四种AOP实战应用场景及代码实现

《SpringBoot中四种AOP实战应用场景及代码实现》面向切面编程(AOP)是Spring框架的核心功能之一,它通过预编译和运行期动态代理实现程序功能的统一维护,在SpringBoot应用中,AO... 目录引言场景一:日志记录与性能监控业务需求实现方案使用示例扩展:MDC实现请求跟踪场景二:权限控制与

Android实现定时任务的几种方式汇总(附源码)

《Android实现定时任务的几种方式汇总(附源码)》在Android应用中,定时任务(ScheduledTask)的需求几乎无处不在:从定时刷新数据、定时备份、定时推送通知,到夜间静默下载、循环执行... 目录一、项目介绍1. 背景与意义二、相关基础知识与系统约束三、方案一:Handler.postDel

Java注解之超越Javadoc的元数据利器详解

《Java注解之超越Javadoc的元数据利器详解》本文将深入探讨Java注解的定义、类型、内置注解、自定义注解、保留策略、实际应用场景及最佳实践,无论是初学者还是资深开发者,都能通过本文了解如何利用... 目录什么是注解?注解的类型内置注编程解自定义注解注解的保留策略实际用例最佳实践总结在 Java 编程

一文教你Python如何快速精准抓取网页数据

《一文教你Python如何快速精准抓取网页数据》这篇文章主要为大家详细介绍了如何利用Python实现快速精准抓取网页数据,文中的示例代码简洁易懂,具有一定的借鉴价值,有需要的小伙伴可以了解下... 目录1. 准备工作2. 基础爬虫实现3. 高级功能扩展3.1 抓取文章详情3.2 保存数据到文件4. 完整示例

使用Python实现IP地址和端口状态检测与监控

《使用Python实现IP地址和端口状态检测与监控》在网络运维和服务器管理中,IP地址和端口的可用性监控是保障业务连续性的基础需求,本文将带你用Python从零打造一个高可用IP监控系统,感兴趣的小伙... 目录概述:为什么需要IP监控系统使用步骤说明1. 环境准备2. 系统部署3. 核心功能配置系统效果展

Python实现微信自动锁定工具

《Python实现微信自动锁定工具》在数字化办公时代,微信已成为职场沟通的重要工具,但临时离开时忘记锁屏可能导致敏感信息泄露,下面我们就来看看如何使用Python打造一个微信自动锁定工具吧... 目录引言:当微信隐私遇到自动化守护效果展示核心功能全景图技术亮点深度解析1. 无操作检测引擎2. 微信路径智能获

使用Java将各种数据写入Excel表格的操作示例

《使用Java将各种数据写入Excel表格的操作示例》在数据处理与管理领域,Excel凭借其强大的功能和广泛的应用,成为了数据存储与展示的重要工具,在Java开发过程中,常常需要将不同类型的数据,本文... 目录前言安装免费Java库1. 写入文本、或数值到 Excel单元格2. 写入数组到 Excel表格

Python中pywin32 常用窗口操作的实现

《Python中pywin32常用窗口操作的实现》本文主要介绍了Python中pywin32常用窗口操作的实现,pywin32主要的作用是供Python开发者快速调用WindowsAPI的一个... 目录获取窗口句柄获取最前端窗口句柄获取指定坐标处的窗口根据窗口的完整标题匹配获取句柄根据窗口的类别匹配获取句

在 Spring Boot 中实现异常处理最佳实践

《在SpringBoot中实现异常处理最佳实践》本文介绍如何在SpringBoot中实现异常处理,涵盖核心概念、实现方法、与先前查询的集成、性能分析、常见问题和最佳实践,感兴趣的朋友一起看看吧... 目录一、Spring Boot 异常处理的背景与核心概念1.1 为什么需要异常处理?1.2 Spring B