SAP BSP 和 JSP 页面里 UI 元素的 ID 生成逻辑
CRM WebClient UI
WebUI最后渲染出来的dom element这些C#_W#的id是在哪行ABAP代码被render出来的?
See my blog WebClient UI element ID generation logic
https://blogs.sap.com/2018/01/31/webclient-ui-element-id-generation-logic/
Hybris
既然是JSP,套路都一样的。Hybris application developer不用重复造轮子,直接在jsp page里使用ycommerce tag:
这个ycommerce tag的实现如下。从注释里也能清楚看出这个JSP tag的实现,为了确保id唯一,采用的是和CRM WebClient UI一样的方式:内部维护一个计数器,每次生成element后加1.
计数器加一的代码:
等价于WebClient UI第16行代码:
JSP没办法直接被浏览器执行,而是编译成.class,最后浏览器输出的native html source code来自这些.class:
既然一个是BSP,一个是JSP,当然有很多相通之处了。
CRM WebUI
每个应用的入口都是search,为了避免application developer重复造轮子,SAP WebUI的框架开发人员把搜索的逻辑实现在了tag advancedSearch里,这样SAP的应用开发人员就可以直接使用这个tag来实现搜索功能。
双击tag,可以看到实现的class和对应方法。
Hybris
jsp有类似的逻辑。看jsp抬头的那些定义,和BSP几乎一模一样。注意第8行的cms:component, 此处将一个UI component include进来。
runtime这个jsp的source code也会被转换成原生的html source code:
每个tag的render逻辑也分为render前,render中和render后。
请和BSP这个三个方法相比:
在执行具体render时,采取的逻辑也是delegate给对应的render class进行render。这个逻辑和Fiori控件的render方式一致,见我的文章A Tutorial how I do self-study on a given Fiori control and UI5 framework code behind里的第2篇: Control renderer:
- 点赞
- 收藏
- 关注作者
评论(0)