广皓图文建站品牌

13518219792
  • 南部网站建设
  • 关于我们
    • 如何选择
    • 选择理由
  • 案例作品
    • 网站建设
    • 优化推广
    • 微信开发
    • 电商托管
  • 服务项目
    • 网站建设
    • 移动端/APP
    • 微信/小程序
    • 技术支持
    • 其它服务
  • 建站知识
    • 南部网站建设
    • 南部做网站
    • 南部网站设计
  • 网站售后
    • 南部网站运营
    • 南部网站维护
    • 南部网站推广
  • 客服中心
  • 全国分站

JavaScript中如何对大量数据的多重过滤

本篇文章为大家展示了JavaScript中如何对大量数据的多重过滤,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。

创新互联-企业级云服务器提供商,为用户提供云服务器、CDN、云安全服务、中国电信成都枢纽中心、服务器租用、高防服务器租用等全方位云服务与各行业解决方案,帮助企业及个人极速备案,轻松上云,安全无忧。

所有代码使用 ES2015 语法,需要 ES5 语法的可以用 Babel - Try it out 或者 TypeScript Playground  翻译。

问题提出

今天有朋友问我一个问题,前端通过 Ajax 从后端取得了大量的数据,需要根据一些条件过滤,过滤的方法是这样的:

class Filter {     filterA(s) {         let data = this.filterData || this.data;         this.filterData = data.filter(m => m.a === s);     }          filterB(s) {         let data = this.filterData || this.data;         this.filterData = data.filter(m => m.b === s);     } }

现在迷糊了,觉得这样处理数据不对,但是又不知道该怎么处理。

发现问题

问题就在过滤上,这样固然可以实现多重过滤(先调用 filterA() 再调用 filterB()  就可以实现),但是这个过滤是不可逆的。假如过滤过程是这样:

f.filterA("a1"); f.filterB("b1"); f.filterA("a2");

本来是希望按 "a1" 和 "b1" 过滤了数据之后,再修改***个条件为 "a2",但结果却成了空集。

解决问题

发现了问题,就针对性的解决。这个问题既然是因为过滤过程不可逆造成的,那每次都直接从 this.data 开始过滤,而不是从this.filterData  开始过滤,就能解决问题。如果要这样做,就需要将选择的过滤条件先记录下来。

记录过滤条件

用一个列表记录过滤条件当然是可行的,但是注意对同一个条件的两次过滤是互斥的,只能保留***一个,所以应该用 HashMap 更为合适。

class Filter {     constructor() {         this.filters = {};     }      set(key, filter) {         this.filters[key] = filter;     }      getFilters() {         return Object.keys(this.filters).map(key => this.filters[key]);     } }

这种情况下,像上面的过程表示为

f.set("A", m => m.a === "a1"); f.set("B", m => m.b === "b1"); f.set("A", m => m.a === "a1"); let filters = f.getFilters(); // length === 2;

上面第 3 句设置的 filter 覆盖了第 1 句设置的那个。现在再用***取得的 filters 依次来过滤原数据  this.data,就能得到正确的结果。

有人会觉得 getFilters() 返回的列表不是按 set 的顺序的——的确,这是 HashMap  的特点,无序。不过对于简单条件的判断,不管谁先谁后,结果是一样的。但是对于一些复合条件判断,就可能会有影响。

确实需要的话,可以通过 array 代替 map 来解决一下顺序的问题,但这样查找效率会降低(线性查找)。如果还想解决查找效率的问题,可以用 array  + map 来处理。这里就不多说了。

过滤

实际上在使用的时候,每次都 getFilter() 再用一个循环来处理确实比较慢。既然 data 都封装成 Filter  中,可以考虑直接给一个filter() 方法来送货过滤接口。

class Filter {     filter() {         let data = this.data;         for (let f of this.getFilters()) {             data = data.filter(f);         }         return data;     } }

不过这样我觉得效率不太好,尤其是对大量数据的时候。不妨利用一下 lodash 的延迟处理过程。

利用 lodash 的延迟处理

filter() {     let chain = _(this.data);     for (let f of this.getFilters()) {         chain = chain.filter(f);     }     return chain.value(); }

lodash 在数据大于 200 的时候会启用延迟处理过程,也就是说,它会处理成一个循环中依次调用每一个 filter,而不是对每一个 filter  进行一次循环。

延迟处理和非延迟处理通过下图可以看出来区别。非延迟处理总共会进行 n(这里 n = 3) 次大循环,产生 n - 1  个中间结果。而延迟处理只会进行一次大循环,没有中间结果产生。

JavaScript中如何对大量数据的多重过滤

不过说实在的,我不太喜欢为了一点小事多加载一个库,所以干脆自己做个简单的实现

自己实现延迟处理

filter() {     const filters = this.getFilters();     return data.filter(m => {         for (let f of filters) {             // 如果某个 filter 已经把它过滤掉了,也不用再用后面的 filter 来判断了             if (!f(m)) {                 return false;             }         }         return true;     }); }

里面的 for 循环还可以用 Array.prototype.every 来简化:

filter() {     const filters = this.getFilters();     return data.filter(m => {         return filters.every(f => f(m));     }); }

数据过滤其实并不是多复杂的事情,只要把思路理清楚,搞明白什么数据是需要保留的,什么数据是临时(中间过程)的,什么数据是最终结果。利用  Array.prototype 中的相关方法,或者诸如 lodash 之类的工具,很容易就处理出来了。

上述内容就是JavaScript中如何对大量数据的多重过滤,你们学到知识或技能了吗?如果还想学到更多技能或者丰富自己的知识储备,欢迎关注创新互联行业资讯频道。


新闻标题:JavaScript中如何对大量数据的多重过滤
地址分享:http://ndjierui.cn/article/pposso.html
扫二维码与项目经理沟通

我们在微信上24小时期待你的声音

解答本文疑问/技术咨询/运营咨询/技术建议/互联网交流

其他资讯

  • pre样式css,pre形式新颖
  • 包含windows前台系统的词条
  • nosql的底层原理,nosql三大理论基础
  • python求函数,Python求函数的解
  • 鸿蒙生态表盘开发,鸿蒙 表盘

行业动态

企业网站建设的重要性!

现在虽然是移动互联网时代,但企业网站依然重要,包含PC站点,移动站。可以说企业网站关系企业的未来发展和前途,尤其对中小企业更是如此,一些中小企业老板,对自己的名片很在乎,因为这是个门面。...

服务项目

  • 网站建设

    查看详情
  • 移动端/APP

    查看详情
  • 微信/小程序

    查看详情
  • 技术支持

    查看详情
  • 其它服务

    查看详情
  • 更多服务项目

    用我们的专业和诚信赢得您的信赖,从PC到移动互联网均有您想要的服务!

    获取更多

联系吧 在百度地图上找到我们

电话:13518219792

如遇占线或暂未接听请拨:136xxx98888

业务咨询 技术咨询 售后服务
网站设计
成都网站设计
响应式网站设计
温江网站设计
成都品牌网站设计
网站制作
重庆网站制作
绵阳网站制作
手机网站制作
定制网站制作
联系我们
电话:13518219792
邮箱:631063699@qq.com
地址:成都青羊区锦天国际1002号
网址:www.ndjierui.cn
网站建设
成都网站建设
品牌网站建设
成都网站建设
企业网站建设

微信二维码

  • 友情链接
  • 成都发电机租赁
  • kmxishu.com
  • 成都二枢机房
  • 宜宾柴油发电机
  • 成都网站续费公司
  • 宜宾网站设计
  • 合影拍摄
  • 成都网站设计
  • 成都小程序商城
  • 郫县明安消防器材

Copyright © 2002-2025 www.ndjierui.cn 广皓图文建站品牌 QQ:244261566 版权所有 备案号:蜀ICP备2025118593号-2

  • 在线咨询
  • 13518219792
  • 微信二维码

  • 移动版官网