昨天是2020年的最初一天,我终日的工夫,都在和两位欧洲共事一起解决一个SAP Spartacus UI里的Checkbox bug.

解决完bug之后,很天然地回忆起了这么多年来,我经验过的不同SAP产品里的Checkbox的设计与实现。

文章目录

(1) SAP GUI里的Checkbox
(2) SAP CRM里的Checkbox
(3) SAP Cloud for Customer里的Checkbox
(4) SAP UI5里的Checkbox
(5) SAP S/4HANA里的Checkbox
(6) SAP Spartacus里的Checkbox

本文介绍前三局部,其中历史最悠久的当然就是SAP GUI里的Checkbox.

值得一提的是,SAP GUI Screen里的控件也反对Keyboard Accessibility,即通过键盘的Tab键,能够逐个导航到屏幕上的每一个控件。

SAP CRM WebClient UI实质上还是ABAP BSP技术,其Checkbox的一个例子,如下图Main Partner列:

一个用户肉眼可见的Checkbox,在SAP CRM零碎里由总共6个HTML标签组合而成。

当Checkbox里的勾选中时,最外层的wrapper div标签的class变为th-sapcb-chkd,chkd是checked的缩写。 内层a标签属性值aria-checked设置为true.

div内层一个暗藏的input标签,如下图标号6所示,用于同ABAP后盾进行值传递,其value属性值变为X.

当Checkbox勾选时,上述介绍的最外层wrapper div的class变为th-sapcb-blk, blk意为blank; 内层a标签的aria-checked属性设置为false,hidden input的value属性值置空。

而Checkbox的小勾视觉效果,通过a标签的CSS::before选择器实现。如上图黄色所示。

::before选择器的用法,通过上面这个简略的例子能够学会——在施加了::before选择器的HTML元素前部,会主动呈现选择器content属性指定的内容。

'\e05d'代表小勾的视觉效果:

咱们试着在Chrome开发者工具里将这个content属性值改一改。'\e05c'代表hint,一个小感叹号:

'\e05d'代表group:

::before选择器的width和height属性管制Checkbox矩形框的宽和高:

这一套::before content属性值和对应的icon视觉效果图的映射关系,能够在这个链接里取得:

https://sapui5.hana.ondemand....

当然,SAP CRM的开发人员,是不会间接编写原生的HTML代码的。在SAP CRM里须要将一个控件定义成Checkbox,只须要实现这个控件绑定的模型节点字段的GET_P办法:

外面将控件的fp_fieldtype设置为field_type_checkbox.

Jerry之前的文章 SAP UI 搜寻分页技术 提到,SAP CRM UI采纳服务器端渲染技术,WebClient UI框架基于上述保护的控件元数据,为一个Checkbox控件,在ABAP端渲染出上述介绍的总共7个HTML元素对应的原生HTML代码。

SAP Cloud for Customer(C4C)里的Checkbox

SAP C4C里的Checkbox颜值较之SAP GUI和SAP CRM有了很大的晋升:

同SAP CRM一样,SAP C4C最终渲染出的HTML页面里,也是由多个HTML元素协同工作,造成最初的Checkbox视觉效果。

C4C的Checkbox处于未选中状态时,wrapper div的aria-checked属性值为false, 内层div被赋予css类sapMSwtOff,span节点的值为No:

Checkbox处于选中状态时,aria-checked属性切换为true,内层div的class切换成sapMSwtOn, span的值为Yes:

C4C里的Checkbox,视觉效果上并不是SAP GUI里和SAP CRM里奢侈的小勾,而是一个相似抽屉的滑动成果。

这个成果并未像SAP CRM那样采取::before实现,而是通过给一个div标签同时增加sapMSwtOn和sapMSwtHandle这两个类实现的,handle的字面意思即抽屉的把手。

Checkbox敞开状态的把手视觉效果通过sapMSwtOff和sapMSwtHandle这两个类独特实现,把手尺寸通过sapUiSizeCompact的height和width管制:

当然,SAP C4C二次开发人员也不须要间接编写这些原生的HTML代码,而是在SAP C4C UI Designer里,从控件工具箱里拖拽一个Checkbox类型的控件到UI编辑界面即可实现Checkbox成果。

本文后续会接着简略介绍SAP UI5,SAP S/4HANA和SAP Spartacus里的Checkbox设计,感激浏览。

更多Jerry的原创文章,尽在:"汪子熙":