前端实现列表多条件查询/搜索功能

2024-06-22 18:28

本文主要是介绍前端实现列表多条件查询/搜索功能,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在前端开发中,实现一个多条件查询功能是常见的需求,尤其是在处理表格数据时。下面我将通过一个简单的Vue组件示例,来展示如何实现一个多条件查询功能。

组件数据结构

首先,定义组件的数据结构,包括查询条件和过滤后的表格数据:

data() {return {// 列表搜索条件cseAttributeData: {parcelCode: "",landType: "",isIndexesCover: "",toSellTaskState: "",manageState: "",signDownState: "",withdrawalWay: ""},filterTableData: [], // 原始数据tableData: [] // 过滤后的数据};
}

方法一:逐个条件过滤

此方法是通过遍历所有查询条件,然后对每个条件应用过滤函数。这种方法的好处是逻辑清晰,易于理解。

methods: {// 图层属性列表查询按钮cseAttributeDataSubmit() {let arr = this.filterTableData;// 通过遍历key值来循环处理Object.keys(this.cseAttributeData).forEach(key => {// 调用筛选方法arr = this.filterFunc(this.cseAttributeData[key], key, arr);});// 为表格赋值this.tableData = arr;},// 筛选方法filterFunc(val, target, filterArr) {// 参数不存在或为空时,返回全部数据if (!val) return filterArr;// 应用过滤条件return filterArr.filter(item => item[target] && item[target].indexOf(val) > -1);}
}

方法二:一次性过滤所有条件

此方法是一次性过滤所有条件,这种方法可以减少遍历次数,提高效率。

methods: {// 图层属性列表查询按钮cseAttributeDataSubmit() {this.tableData = this.filterTableData.filter(item => {// 遍历所有查询条件for (const [k, v] of Object.entries(this.cseAttributeData)) {if (v) { // 如果条件不为空if (!item[k] || !item[k].includes(v)) {return false; // 如果当前项不包含查询条件,则过滤掉}}}return true; // 如果所有条件都满足,则保留});}
}

总结

两种方法各有优缺点:

  • 方法一逻辑清晰,易于理解,但可能效率略低。
  • 方法二效率更高,但逻辑稍微复杂一些。

在选择实现方法时,可以根据实际项目需求和数据量大小来决定使用哪种方法。如果数据量不大,推荐使用方法一,因为它更易于维护和理解。如果数据量较大,或者需要更高效的查询,可以考虑使用方法二。

注意事项

  • 确保查询条件不为空时才进行过滤。
  • 根据实际数据类型,可能需要对查询条件和数据进行类型转换,比如toLowerCase()
  • 考虑使用Vue的计算属性(computed)来自动更新表格数据,以提高性能。

这篇关于前端实现列表多条件查询/搜索功能的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

C++对象布局及多态实现探索之内存布局(整理的很多链接)

本文通过观察对象的内存布局,跟踪函数调用的汇编代码。分析了C++对象内存的布局情况,虚函数的执行方式,以及虚继承,等等 文章链接:http://dev.yesky.com/254/2191254.shtml      论C/C++函数间动态内存的传递 (2005-07-30)   当你涉及到C/C++的核心编程的时候,你会无止境地与内存管理打交道。 文章链接:http://dev.yesky

房产证 不动产查询

陕西政务服务网(便民服务)陕西政务服务网(手机版?更直观)不动产权证书|不动产登记证明(电子证照)商品房合同备案查询权利人查询

vue, 左右布局宽,可拖动改变

1:建立一个draggableMixin.js  混入的方式使用 2:代码如下draggableMixin.js  export default {data() {return {leftWidth: 330,isDragging: false,startX: 0,startWidth: 0,};},methods: {startDragging(e) {this.isDragging = tr

通过SSH隧道实现通过远程服务器上外网

搭建隧道 autossh -M 0 -f -D 1080 -C -N user1@remotehost##验证隧道是否生效,查看1080端口是否启动netstat -tuln | grep 1080## 测试ssh 隧道是否生效curl -x socks5h://127.0.0.1:1080 -I http://www.github.com 将autossh 设置为服务,隧道开机启动

通过高德api查询所有店铺地址信息

通过高德api查询所有店铺地址电话信息 需求:通过高德api查询所有店铺地址信息需求分析具体实现1、申请高德appkey2、下载types city 字典值3、具体代码调用 需求:通过高德api查询所有店铺地址信息 需求分析 查询现有高德api发现现有接口关键字搜索API服务地址: https://developer.amap.com/api/webservice/gui

时序预测 | MATLAB实现LSTM时间序列未来多步预测-递归预测

时序预测 | MATLAB实现LSTM时间序列未来多步预测-递归预测 目录 时序预测 | MATLAB实现LSTM时间序列未来多步预测-递归预测基本介绍程序设计参考资料 基本介绍 MATLAB实现LSTM时间序列未来多步预测-递归预测。LSTM是一种含有LSTM区块(blocks)或其他的一种类神经网络,文献或其他资料中LSTM区块可能被描述成智能网络单元,因为

vue项目集成CanvasEditor实现Word在线编辑器

CanvasEditor实现Word在线编辑器 官网文档:https://hufe.club/canvas-editor-docs/guide/schema.html 源码地址:https://github.com/Hufe921/canvas-editor 前提声明: 由于CanvasEditor目前不支持vue、react 等框架开箱即用版,所以需要我们去Git下载源码,拿到其中两个主

React+TS前台项目实战(十七)-- 全局常用组件Dropdown封装

文章目录 前言Dropdown组件1. 功能分析2. 代码+详细注释3. 使用方式4. 效果展示 总结 前言 今天这篇主要讲全局Dropdown组件封装,可根据UI设计师要求自定义修改。 Dropdown组件 1. 功能分析 (1)通过position属性,可以控制下拉选项的位置 (2)通过传入width属性, 可以自定义下拉选项的宽度 (3)通过传入classN

android 免费短信验证功能

没有太复杂的使用的话,功能实现比较简单粗暴。 在www.mob.com网站中可以申请使用免费短信验证功能。 步骤: 1.注册登录。 2.选择“短信验证码SDK” 3.下载对应的sdk包,我这是选studio的。 4.从头像那进入后台并创建短信验证应用,获取到key跟secret 5.根据技术文档操作(initSDK方法写在setContentView上面) 6.关键:在有用到的Mo

android一键分享功能部分实现

为什么叫做部分实现呢,其实是我只实现一部分的分享。如新浪微博,那还有没去实现的是微信分享。还有一部分奇怪的问题:我QQ分享跟QQ空间的分享功能,我都没配置key那些都是原本集成就有的key也可以实现分享,谁清楚的麻烦详解下。 实现分享功能我们可以去www.mob.com这个网站集成。免费的,而且还有短信验证功能。等这分享研究完后就研究下短信验证功能。 开始实现步骤(新浪分享,以下是本人自己实现