js数组Array根据动态条件过滤
数据
[{
"name": "张三",
"score": 153
}, {
"name": "李四",
"score": 206
}, {
"name": "王五",
"score": 68.5
}, {
"name": "王六",
"score": 83.5
}]
需求:需要根据动态的条件来对数据进行查询。
步骤1:定义过滤器并初始化,比如我们要查询王五以6分开头的数据,条件定义:`姓名 equal 王五 && 成绩 beginWith 6`
/// 过滤器集合,格式:{field:'',relationType:'',value: ''}
/// field - 用于过滤的属性(字段)
/// relationType - 关联关系(比较方式),可选值有equal(等于)、notEqual(不等于)、like(模糊匹配)、beginWith(以它开头)、endWith(以它结尾)
/// value - 用于被比较的过滤器值
const filters = []
filters.push({
field: 'name',
relationType: 'equal',
value: '王五'
})
filters.push({
field: 'score',
relationType: 'beginWith',
value: '6'
})
步骤2:定义一个通用的过滤函数,过滤函数传递2个参数,第1个是需要被过滤的数据源,第2个是过滤器集合,函数返回值是过滤后的数据源
// 过滤数据源
function filteringDataSources (source, filters) {
// 动态表达式集合,用于存储判断某个对象是否满足条件的函数
const expressions = []
// 遍历过滤器集合,动态添加表达式函数
filters.forEach(item => {
// 添加表达式函数,参数为数组的每个数据对象
expressions.push((obj) => {
// 是否符合条件
let isFit = false
// 数据对象对应的属性值
let objValue = ''
// 用于被比较的过滤器值
const compareValue = item.value
// 判断数据对象是否存在用于过滤的属性,如果不存在直接判定为不符合条件
if (typeof (obj[item.field]) === 'undefined') {
isFit = false
return isFit
} // 获取数据对象用于比较的属性值,统一转为字符串类型,便于比较
objValue = String(obj[item.field]) // 判断逻辑
if (item.relationType === 'equal') { // 等于
isFit = objValue === compareValue
} else if (item.relationType === 'notEqual') { // 不等于
isFit = objValue !== compareValue
} else if (item.relationType === 'like') { // 模糊匹配
isFit = objValue.includes(compareValue)
} else if (item.relationType === 'beginWith') { // 以它开头
isFit = objValue.startsWith(compareValue)
} else if (item.relationType === 'endWith') { // 以它结尾
isFit = objValue.endsWith(compareValue)
} // 返回当前表达式是否符合条件
return isFit
})
}) // 遍历数据源
source = source.filter((item, index) => {
// 是否符合条件
let isFit = true
// 遍历表达式集合,循环判断每个用于过滤的表达式函数是否符合
for (let index = 0; index < expressions.length; index++) {
// 获取表达式函数
const expression = expressions[index]
// 调用表达式函数,获取结果
const result = expression(item)
// 如果结果为false,则终止表达式集合的遍历(即有一个条件不符合,则该条数据则被判定不满足条件)
if (!result) {
isFit = false
break
}
} // 返回当前数据对象是否符合条件,不符合条件则被过滤掉,不会出现在最终数据中
return isFit
}) // 返回过滤后的数据源
return source
}
步骤3:调用过滤函数得到结果
if (filters.length > 0) {
source = filteringDataSources(source, filters)
}
结果:
Array(1)
0: {name(test_scores): "王五", score(test_scores): 68.5}
length: 1
完整代码:
// 过滤数据源
function filteringDataSources (source, filters) {
// 动态表达式集合,用于存储判断某个对象是否满足条件的函数
const expressions = []
// 遍历过滤器集合,动态添加表达式函数
filters.forEach(item => {
// 添加表达式函数,参数为数组的每个数据对象
expressions.push((obj) => {
// 是否符合条件
let isFit = false
// 数据对象对应的属性值
let objValue = ''
// 用于被比较的过滤器值
const compareValue = item.value
// 判断数据对象是否存在用于过滤的属性,如果不存在直接判定为不符合条件
if (typeof (obj[item.field]) === 'undefined') {
isFit = false
return isFit
} // 获取数据对象用于比较的属性值,统一转为字符串类型,便于比较
objValue = String(obj[item.field]) // 判断逻辑
if (item.relationType === 'equal') { // 等于
isFit = objValue === compareValue
} else if (item.relationType === 'notEqual') { // 不等于
isFit = objValue !== compareValue
} else if (item.relationType === 'like') { // 模糊匹配
isFit = objValue.includes(compareValue)
} else if (item.relationType === 'beginWith') { // 以它开头
isFit = objValue.startsWith(compareValue)
} else if (item.relationType === 'endWith') { // 以它结尾
isFit = objValue.endsWith(compareValue)
} // 返回当前表达式是否符合条件
return isFit
})
}) // 遍历数据源
source = source.filter((item, index) => {
// 是否符合条件
let isFit = true
// 遍历表达式集合,循环判断每个用于过滤的表达式函数是否符合
for (let index = 0; index < expressions.length; index++) {
// 获取表达式函数
const expression = expressions[index]
// 调用表达式函数,获取结果
const result = expression(item)
// 如果结果为false,则终止表达式集合的遍历(即有一个条件不符合,则该条数据则被判定不满足条件)
if (!result) {
isFit = false
break
}
} // 返回当前数据对象是否符合条件,不符合条件则被过滤掉,不会出现在最终数据中
return isFit
}) // 返回过滤后的数据源
return source
} let source = [{
'name': '张三',
'score': 153
}, {
'name': '李四',
'score': 206
}, {
'name': '王五',
'score': 68.5
}, {
'name': '王六',
'score': 83.5
}]
/// 过滤器集合,格式:{field:'',relationType:'',value: ''}
/// field - 用于过滤的属性(字段)
/// relationType - 关联关系(比较方式),可选值有equal(等于)、notEqual(不等于)、like(模糊匹配)、beginWith(以它开头)、endWith(以它结尾)
/// value - 用于被比较的过滤器值
const filters = []
filters.push({
field: 'name',
relationType: 'equal',
value: '王五'
})
filters.push({
field: 'score',
relationType: 'beginWith',
value: '6'
})
source = filteringDataSources(source, filters)
console.log(source)
PS:动态条件过滤来自于工作中的一个需求
过滤前:

过滤后:

js数组Array根据动态条件过滤的更多相关文章
- JS数组array常用方法
JS数组array常用方法 1.检测数组 1)检测对象是否为数组,使用instanceof 操作符 if(value instanceof Array) { //对数组执行某些操作 } 2)获取对象的 ...
- 「面试指南」JS数组Array常用算法,Array算法的一般解答思路
先看一道面试题 在 LeetCode 中有这么一道简单的数组算法题: // 给定一个整数数组 nums 和一个目标值 target, // 请你在该数组中找出和为目标值的那两个整数,并返回他们的数组下 ...
- 【转】 js数组 Array 交集 并集 差集 去重
原文:http://blog.csdn.net/ma_jiang/article/details/52672762 最劲项目需要用到js数组去重和交集的一些运算,我的数组元素个数可能到达1000以上, ...
- [学习笔记]JS 数组Array push相关问题
前言: 今天用写了一个二维数组,都赋值为零,然后更新其中一个值,结果和预期是不一样,会整列的相同位置都是同一个值. 1.用Chrome的控制台样例如下: arrs[2][2] =1的赋值,竟然是三个数 ...
- js — 数组Array
目录 1. isArray 2. 转换方法 3. 分割字符串 join 4. 栈方法 5. 队列方法 6. 重排序方法 7. 操作方法 8. 位置方法 - 索引 9. 迭代方法 数组 array 解释 ...
- JS数组 Array
1.创建数组 var array=new Array(); 2.添加数组 array.push("111"); array.push("111"); array ...
- JS数组(Array)处理函数总结
1.concat() 连接两个或更多的数组该方法不会改变现有的数组,而仅仅会返回被连接数组的一个副本.例如: <script type="text/javascript"&g ...
- js数组Array方法
1. indexOf indexOf()方法返回在该数组中第一个找到的元素位置,如果它不存在则返回-1. var fruits = ["Banana", "Orange& ...
- js 数组array es5-es6+ 新增方法函数
arr.forEach(function(item,index,arr){},this) 相当于普通的for循环,第一个回调参数,第二个this可以重定向[箭头函数则不生效] arr.map() 非 ...
随机推荐
- Django学习路34_models 文件创建数据表
from django.db import models # Create your models here. class BookInfoManager(models.Manager): '''图书 ...
- 提取txt文本有效内容
原理: 1.使用足够多的垃圾邮件和非垃圾邮件的内容作为训练集 2.读取全部训练集 删除其中的干扰字符 [ ] ,* . 进行分词 删除长度为 1 的单个字符 3.统计全部训练集中每个有效词汇的出现次数 ...
- 5.4 省选模拟赛 修改 线段树优化dp 线段树上二分
LINK:修改 题面就不放了 大致说一下做法.不愧是dls出的题 以前没见过这种类型的 不过还是自己dp的时候写丑了. 从这道题中得到一个结论 dp方程要写的优美一点 不过写的过丑 优化都优化不了. ...
- luogu P4321 随机漫游 期望dp 二进制 高斯消元
LINK:随机漫游 非常妙的一道题. 容易想到倒推期望. 设状态 f[i][j]表示到达第i个点 此时已经到达的集合为j能走到全集的期望边数. 只要求出来这个就能O(1)回答询问. \(f[i][j] ...
- luogu P3223 [HNOI2012]排队
LINK:排队\ 原谅我没学过组合数学 没有高中数学基础水平... 不过凭着隔板法的应用还是可以推出来的. 首先考虑女生 发现一个排列数m! 两个女生不能相邻 那么理论上来说存在无解的情况 而这道题好 ...
- Java自学-JDBC 数据库连接池
数据库连接池 与线程池类似的,数据库也有一个数据库连接池. 不过他们的实现思路是不一样的. 本章节讲解了自定义数据库连接池类:ConnectionPool,虽然不是很完善和健壮,但是足以帮助大家理解C ...
- js数组中如何去除重复值?
在日常开发中,我们可能会遇到将一个数组中里面的重复值去除,那么,我就将我自己所学习到的几种方法分享出来 去除数组重复值方法: 1,利用indexOf()方法去除 思路:创建一个新数组,然后循环要去重的 ...
- FastAPI框架入门 基本使用, 模版渲染, form表单数据交互, 上传文件, 静态文件配置
安装 pip install fastapi[all] pip install unicorn 基本使用(不能同时支持,get, post方法等要分开写) from fastapi import Fa ...
- ECS7天实践进阶训练营Day1:使用阿里云ECS,快速搭建、管理VuePress静态网站
一.概述 VuePress是2018年由尤雨溪发布的一个全新的基于Vue的静态网站生成器,它是一个非常轻量级的静态网站生成器.VuePress主要用于生成技术文档,其类似于Gitbook,我们可以用于 ...
- jQuery 基本用法
1)页面加载完成后开始运行do stuff when DOM is ready 中的语句! $(document).ready(function() { // do stuff when DOM is ...