SAP Fiori 注解 @ObjectModel.readOnly工作原理解析

SAP Fiori 注解,是 ABAP Programming Model for SAP Fiori 的重要概念之一。

ABAP Programming Model for SAP Fiori 适用于 SAP NetWeaver AS for ABAP 7.51 innovation package, SP00 或者更高的版本。对底层数据库没有要求,推荐使用 SAP HANA.

开发人员需要具备如下的 PFCG role:

  • SAP_BC_DWB_ABAPDEVELOPER
  • SAP_BC_DWB_WBDISPLAY
  • /IWFND/RT_DEVELOPER (用于 SAP Gateway service 开发).

架构如下:

SAP Fiori 注解 @ObjectModel.readOnly工作原理解析_第1张图片

作为SAP客户,在某些情况下,可能希望扩展SAP或SAP合作伙伴交付的On-Premise应用程序的用户界面(UI)。

字段可扩展性(Fiori Extensibility)意味着客户希望在给定的业务应用程序上下文中提供额外的字段,该上下文由实际使用的UI表示。这些字段是SAP交付时应用程序没有预见到的。在这种情况下,可以选择使用ABAP平台的可扩展基础设施,以便向原始应用程序添加自定义字段。这个基础设施首先需要确保将新的数据元素添加到持久性(数据库表)和之间所有涉及的层(ABAP Dictionary、CDS、SAP Gateway服务)。基础设施还需要再次向应用程序UI的服务元数据公开,以供其他消费者使用。

可以在不同的场景中使用此基础设施:

  • Key User Extensibility:只对可配置的扩展感兴趣,因为它们是在业务高级用户(关键用户)适配上下文中使用的。
  • 自定义代码可扩展性——希望通过实现自己的扩展,通过自定义代码这种编程方式,最大限度地利用该基础设施的字段可扩展性。

关键用户可扩展性允许关键用户创建自定义字段,如果SAP应用程序启用了可扩展性。关键用户具有业务透视图,不需要关心技术细节。因此,关键用户最终能够创建和更改自定义字段及其属性(名称、标签、类型或屏幕上的位置)。

如果SAP应用程序启用了可扩展性,优先选择使用关键用户工具来创建自定义字段,即使作为开发人员也是如此,因为关键用户工具隐藏了SAP应用程序的技术细节。另一方面,SAP 建议在以下情况下使用扩展视图直接创建自定义字段:

  • SAP应用程序还没有启用可扩展性
  • 关键用户工具的功能不够充分。例如,希望在自定义字段中进行计算。

我们必须记住,自定义代码可扩展性需要整个开发周期通过代码添加来实现扩展。反过来,这就需要对最初以 CDS 视图的形式交付并作为 OData 服务发布以供进一步使用的数据模型进行扩展。

SAP官网的ABAP Programming Model for Fiori帮助文档里,定义了很多注解(Annotation):

SAP Fiori 注解 @ObjectModel.readOnly工作原理解析_第2张图片

对于这些注解,我们可以从其字面含义和SAP帮助文档去掌握其用法和功能。

SAP Fiori 注解 @ObjectModel.readOnly工作原理解析_第3张图片

以@ObjectModel.readOnly为例,施加了这个注解的CDS view字段,在对应的Fiori UI上以只读的方式渲染:

SAP Fiori 注解 @ObjectModel.readOnly工作原理解析_第4张图片

并且也不能通过编程的方式进行修改。

大家在使用这些注解的时候,有没有想过,它们是怎么工作的?

以@ObjectModel.readOnly为例,现在就请跟着笔者一起,去探索它的前后台实现原理。

在Chrome开发者工具的UI5面板里,找到Posting Date这个控件对应的属性,发现字段editable属性值为false,这就是其在UI不能编辑的原因。

SAP Fiori 注解 @ObjectModel.readOnly工作原理解析_第5张图片

既然后台模型是CDS view,那么前台UI显然基于Fiori Elements. 我想知道Posting Date这个控件的editable属性是在什么时候被设置成false的。

在SmartField.setEditable函数里设置断点,重新打开Fiori UI,点击Edit进入编辑模型,断点触发,从调用栈能看出,有代码调用SmartField.setEditable时,传入的参数为false.

SAP Fiori 注解 @ObjectModel.readOnly工作原理解析_第6张图片

那么这个false如何计算出来的?顺着当前的调用栈往外层查找,发现一个重要的函数:
AnnotationHelper.canUpdateProperty.

从函数名就能猜测出,这个函数负责计算一个控件的属性是否允许更新(Update),工作的上下文就是注解(Annotation).

SAP Fiori 注解 @ObjectModel.readOnly工作原理解析_第7张图片

这个方法实现体的语义也很清楚,如果后台模型字段sap:updatable设置为false,则canUpdateProperty函数调用返回false,导致SmartField.setEditable以参数false去渲染Fiori UI.

我们打开OData服务的metadata,发现posting date字段对应的sap:updatable果然为false.

SAP Fiori 注解 @ObjectModel.readOnly工作原理解析_第8张图片

至此Fiori UI的工作原理分析完毕。我们再来看后台。我的CDS view里只添加了@ObjectModel.readOnly为true的注解,而非sap:updatable. 显然,这二者存在一定的关联关系。

SAP Fiori 注解 @ObjectModel.readOnly工作原理解析_第9张图片

第839行的IF判断,如果OBJECTMODEL.READONLY为true,则read_only属性为X.
而read_only属性为true,会导致posting date字段的属性集合内表里,新增一条read_only为X的记录:

SAP Fiori 注解 @ObjectModel.readOnly工作原理解析_第10张图片
SAP Fiori 注解 @ObjectModel.readOnly工作原理解析_第11张图片

最后,在SADL框架的属性检测逻辑中,一旦发现字段属性集合内表里存在read_only为X的属性,则将lv_creatable和lv_updatable置为false.

SAP Fiori 注解 @ObjectModel.readOnly工作原理解析_第12张图片

而SADL框架计算出来的这两个值为false的布尔变量,最后就会将sap:creatable和sap:updatable设置为false.

SAP Fiori 注解 @ObjectModel.readOnly工作原理解析_第13张图片

@ObjectModel.readOnly属性的前后台工作原理的神秘面纱,至此就揭开了,然而它只是SAP Fiori编程模型众多注解的冰山一角。

SAP Fiori 注解 @ObjectModel.readOnly工作原理解析_第14张图片

总结

本文首先概述了 ABAP Programming Model for SAP Fiori 的定义,接着以这种编程模型里一个重要的注解 @ObjectModel.readOnly 为例,详细介绍了 CDS 注解与 ABAP 后台协同工作的技术细节。

你可能感兴趣的:(SAP Fiori 注解 @ObjectModel.readOnly工作原理解析)