正如我上次承诺的那样,我计划浏览该平台的某些功能,这些功能我认为非常有价值。 所以我将在这里做一些系列。 从明显的用户界面,过滤,安全性到一些高级功能(如Web Portal,可扩展性,审核,动态属性等)开始。

CUBA功能#1 –通用过滤器

我想在这篇博客文章中介绍通用过滤器解决方案。 但是在弄清技术细节之前,让我们开始研究此功能解决的基本用例。

用户如何获得实际需要的数据

我们将继续使用上次的示例:

具有客户-订单关系的域示例

基于此实体模型,让我们考虑用户可能具有的一些可能的过滤器要求。

首先,在实体本身及其直接属性上有某些过滤器:

  • 显示纽约的所有客户
  • 显示2015年的所有订单
  • 显示价格最低的所有产品。 350 $
  • 显示处于“已完成”状态的所有订单

接下来,我们基于1:1 / N:1关联进行过滤:

  • 列出客户“ Mario David”的所有订单
  • 列出居住在达拉斯的所有客户(通过地址实体)
  • 显示“笔记本”类别中的所有产品

然后,我们有了基于1:N / M:N关系的过滤器:

  • 列出2015年至少有一个订单的所有客户
  • 列出最多包含五个订单项的所有订单
  • 列出所有订单项的价格总和大于200 $的订单

基本上,这是过滤器要求的类别,可以满足大约80%的用例。

解决这类问题的程序化方式

我通常处理此类要求的方式如下:首先,我将开始着手研究用户实际希望通过此过滤实现的目标。 通常,它仅用于减少当前执行的工作流的实体实例数量。 例如,“仅针对未及时付款的订单进行过滤” –在这种情况下,工作流程将类似于“发送过期通知”。 使用过滤的另一种方法是,如果结果是报告的基础(本博客文章中未介绍)。

无论是什么原因,当我知道过滤条件是什么时,对我来说,作为程序员的一个简单解决方案就是立即实施过滤条件。 如果我们考虑在Grails中实现,那么我会在后端想到这样的东西:

class OrderController {//...Date now = new Date()respond Order.where { dueDate > now }.list(params)//...
}

这将以简化的方式完成这项工作。 在前端,可以使用下拉框或切换按钮。 另一种可能性是通过链接获取该数据,从而将信息保留在其中。

无论采用哪种实现方式–整个解决方案的重点是,作为开发人员,我必须事先了解此过滤器要求,因为必须以编程方式进行实施。

这些问题的通用解决方案

除了按需直接实施过滤器解决方案外,一种更通用的解决方案也很普遍。 在这种情况下,开发人员不预先知道过滤器要求,而是让用户决定要搜索/过滤的内容。 为此,必须从属性的基础数据类型推断出可能的过滤条件。

可以将此模型视为类似于excel 过滤机制。 excel根据当前列的数据类型,提供在这种情况下有意义的过滤器可能性。 可以将日期过滤到一定范围内,数字必须大于给定数字,字符串可以包含某个子字符串,依此类推。 由于Excel并不真正了解实体和关系,因此无法搜索/过滤关联。 因此,此过滤器机制仅在一定程度上有价值。

CUBA带来了什么

因此,CUBA来到这里,告诉我们,其中有一个“通用过滤器”,它使我们可以过滤大多数我们想要的子数据。 让我们更深入地了解它。

产品的CUBA中的通用过滤器示例

我创建了一个演示应用程序 ,该应用程序是上述域模型的实现。 在这里,我们看到了我们商店中可用的产品列表。 在数据表的顶部,您会注意到过滤器部分,可用于定义该表的过滤器。 链接“添加搜索条件”将查看基础实体(在本例中为Product)并显示所有实体。 实际上,不仅显示了实体的直接属性,而且还显示了相关实体及其属性(以及相关实体及其属性以及……)。

选择一些可用属性后,表中的过滤器部分将填充相应的条件框。 根据属性类型,定义条件的可能性会有所不同。

这是过滤条件的这种组合的一个示例:

从类别智能手机中选择所有以Apple开头的产品,自2015年2月11日起更改

根据属性类型,过滤条件可以处于不同的模式。 文本属性可能以给定文本开头包含给定文本,依此类推。 可以使用相应的日期过滤器来过滤日期,例如给定日期之前之后 。 枚举以及“多对一”关联可以通过下拉列表选择。 这种类型的条件模式是setlist=等。我可以继续描述不同的数据类型及其过滤器模式,但现在我将其保留。 如果您想了解所有可能性,请在此处找到一个不错的文档。

我现在展示的内容几乎只是CUBA为用户和开发人员提供有关过滤的可能性的表面。 但是,在考虑时,它具有相当多的功能,可以使用户自行进行过滤。

如您所见,乍看之下,几乎没有什么阻止我(作为开发人员)让用户决定所需的过滤器可能性,而不必手动实现不同的可能性。

要完成这项工作,我需要做什么?

好的,所以有趣的问题可能是,作为开发人员实施此功能需要付出多少努力。 要查看此内容,您必须查看产品列表的UI定义文件 。 基本上它是这样的:

<filter id="filter" datasource="productsDs"><properties include=".*"/>
</filter>

就是这样 。 其实不是,因为你必须做定义productsDs数据源定义,你会在找到XML描述为好。

更精确地说,您通常不会自己编写定义。 相反,您将使用CUBA Studio进行管道。

CUBA Studio显示带有可能性的产品实体以生成屏幕

在这种情况下,您将启动本地Studio安装(并从示例项目中进行git clone),打开该项目,查看您的产品实体(如上所述),并告诉它为其生成标准视图。 在回答了有关此生成步骤的不同选项的几个问题之后,它将为该实体的列表视图提供确切的XML描述符文件,包括过滤器的可能性。

真正的重物是什么?

看到这一点之后,我想到了两件事。 首先,这只是用于特定的过滤方案。 如何预定义此过滤器,以使我的用户不必一遍又一遍地自行挑选它们? 第二件事是,通常存在过滤要求,这些要求超出了所描述的可能性。 CUBA如何解决?

该平台提供了针对这些异议的解决方案。 在本系列的下一部分中,我将对此进行介绍。

翻译自: https://www.javacodegeeks.com/2015/12/the-generic-filter-in-cuba-platform-excel-filters-on-steroids.html

古巴平台上的通用过滤器–类固醇上的excel过滤器相关推荐

  1. 古巴比伦乘法_古巴平台中的通用过滤器–类固醇上的excel过滤器

    古巴比伦乘法 正如我上次承诺的那样,我计划浏览该平台的某些功能,这些功能我认为非常有价值. 所以我将在这里做一些系列. 从明显的用户界面,过滤,安全性到一些高级功能(如Web Portal,可扩展性, ...

  2. Vue 人资 实战篇七 员工管理上 封装通用的组件、formatter属性、过滤器的使用、树形结构、建立公共导入的页面路由、excel的导入和导出、

    1.0 封装一个通用的工具栏 目标:封装一个通用的工具栏供大家使用 1.1 通用工具栏的组件结构 在后续的业务开发中,经常会用到一个类似下图的工具栏,作为公共组件,进行一下封装 组件 src/comp ...

  3. 【干货分享】云服务平台的架构及优势(上)

    来源商业新知网,原标题:[干货分享]云服务平台的架构及优势(上) 前言 我们通常所说的云服务或云平台广义上是一个概念,但其实内部是两个部分. 1.支撑云服务运行的硬件和软件系统环境(云架构平台,简称云 ...

  4. WPF数据驱动应用程序上具有通用Lambda表达式的筛选器模式

    从Github下载源代码 介绍 本文演示了在WPF上具有通用lambda表达式的筛选器模式.筛选器模式与管道一起在数据驱动的应用程序中大量使用.使用C#lambda表达式,可以缩短代码并使代码通用化. ...

  5. 回归云平台的本质,通过平台+应用模式实现软件资源线上共享

    本文作者│欧小刚 微信号│oyg0001 联系邮箱│oxg@soft6.com 云计算发展到今天,平台化成为大家的共识.那么,大家都在谈论的云平台本质到底是什么呢?我想很多人都不一定清楚.在2017年 ...

  6. osgb转json_超实用:一篇文章带你了解市面上主流通用的3D模型格式

    原标题:超实用:一篇文章带你了解市面上主流通用的3D模型格式 3D模型格式知多少 说到格式,相信大家都不陌生. 随着互联网的普及,我们几乎每天都会和不同的格式打交道,文本的TXT.图片的JPG.视频的 ...

  7. html 文件上传_某平台存在多处任意文件上传

    文章来源: EDI安全 01 漏洞标题 某平台存在多处任意文件上传 02 漏洞类型 文件上传 03 漏洞等级 中危 04 漏洞地址 http://xxxx.xxxxx.com/er.app.xxxx/ ...

  8. 华为云平台使用手册_华为云首发全生命周期应用平台,四大能力解决政企上云五大难题...

    9月19日,在华为全联接大会上,华为云正式发布全生命周期应用平台.华为云应用平台服务产品部副总经理汪维敏介绍,华为云无缝整合三大尖刀产品(华为云DevCloud.ServiceStage.ROMA), ...

  9. “网上购车平台”又出低首付上私户新模式

    "网上购车平台"又出低首付上私户新模式 最近市场上出现了不少以低首付为噱头的网上购车平台,低首付就能买新车,看上去极有吸引力.总体 来说它们的运作模式是相同的: 超低首付买车:第一 ...

最新文章

  1. 用户看法调查结果及分析(四)
  2. 职高计算机教学案例 反思,关于职高数学优质课教学案例的研究与反思
  3. 谷歌更强 NLP 模型 XLNet 开源:20 项任务全面碾压 BERT!
  4. iftop 监控linux服务器网卡流量
  5. Git复习(七)之自定义git、忽略特殊文件、配置文件
  6. 【分析】1021 Deepest Root (25 分)【DFS解法】
  7. 如何通过组件化提高开发效率?
  8. NS2安装笔记 - Ubuntu9.10
  9. 二分查找算法java
  10. linux下安装nginx启动,Linux下安装启动nginx的过程
  11. 收集常用汉字6725个
  12. Linux中修改HTTP默认主页
  13. rtsp开源视频播放器VideoLAN
  14. 基于李雅普诺夫函数的跟踪控制(一)
  15. 【DASCTF2023】Misc mp3
  16. MyBatis SQL里的大于号、小于号
  17. java求最短距离_计算多点之间的最短距离
  18. iOS - 添加代码片段(Code Snippets)
  19. java 工具类命名_排名前16的Java工具类
  20. 一篇就可以搞定——ADB连接多台设备问题

热门文章

  1. 06-Mapper动态代理
  2. java后台手动分页
  3. Axios实现异步通信
  4. python网络模块_Python的pyroute2网络模块-阿里云开发者社区
  5. 定时任务重启后执行策略_C语言操作时间函数time.ctime,实现定时执行某个任务小例子...
  6. 分类算法中常用的评价指标
  7. 一文理清HashMap的实现及细节
  8. junit 测试目录_JUnit 5测试中的临时目录
  9. 使用Spring Boot和MongoDB构建一个React式应用程序
  10. 注释嵌套注释_DIY注释