zoukankan      html  css  js  c++  java
  • SAP Fiori Elements原理介绍之类型为Currency的Smart Field工作原理

    What is smart field

    According to SAP help, “Smart controls are a specific category of SAPUI5 controls that have some special features in addition to the standard SAPUI5 features and thus make it easier to use the control in certain scenarios. One important building block of smart controls is the SmartField control that, depending on the OData metadata defined, allows you to renders other controls and, for example, define fields with certain attributes based on the metadata.”

    In xml view definition, only one SmartLabel and one SmartField are declared.

    However, in rendered UI, there is additional currency field displayed as well. This is the meaning of “Smart”.

    How SmartField works

    (1) SmartField which is bound to Price field is rendered as usual:

    (2) The mock data, Products.json, will be loaded by Mock server and once it is available, success callback is triggered.

    (3) In callback, setElementBindingContext will trigger initialization logic of SmartField:


    (4) Here ODataControlFactory will try to get all sap defined annotation from OData Metadata,

    The picture above highlights some of sap annotations. For a complete list of them, please refer to this link.

    Parse logic of all annotations could be find from AnnotationHelper.get. The example below introduces how sap:unit annotation is parsed.


    The string “CurrencyCode” is returned:

    At this time, metadata for currency UI element is available and it is ready for creation:

    (5) UI element for currency code display is created here:

    And CSS class sapUiCompSmartFieldUnit is added:

    要获取更多Jerry的原创文章,请关注公众号"汪子熙":

  • 相关阅读:
    Java总结(三)之String、StringBuffer、StringBuilder区别
    Java总结(二)之字符串常用操作
    Java总结(一)之四类八种数据类型
    schema.xml的配置
    MySQL server has gone away问题得解决方案
    如何在Java中将Excel转化为XML格式文件
    FileItemFactory 接口的介绍
    小练习2
    小练习
    while else 练习题
  • 原文地址:https://www.cnblogs.com/sap-jerry/p/13638879.html
Copyright © 2011-2022 走看看