SAP Fiori globalization实现原理分析

69 阅读1分钟

This issue is copied from one of Jerry’s workshop regarding Fiori Globalization implementation.
You have observed the following behavior: the sales volume is displayed in detail view with 1880 USD, while in master list, it is displayed as 2K for short. Why?

clipboard1

The truncation behavior in master list is implemented by Fiori application to fulfill the product standard of Globalization requirement.
The exact value for SalesVolume is 1880.00,

clipboard2

And for the field in master list, there is a formatter to return the volume in short format:

clipboard3
clipboard4

And in order to understand the implementation detail of framework API “FormatAmountShort”, we have to understand the definition of CLDR - Unicode Common Locale Data Repository.
The Unicode CLDR provides key building blocks for software to support the world’s languages, with the largest and most extensive standard repository of locale data available. This data is used by a wide spectrum of companies for their software internationalization and localization, adapting software to the conventions of different languages for such common software tasks. See one part of CLDR definition below from cldr.unicode.org/translation… :

clipboard5

The first call of FormatAmountShort will trigger the load of CLDR file in the runtime.

clipboard6

The English version of CLDR content defined in the web page cldr.unicode.org/ is packed and stored in JSON file en.json by SAP and is now loaded:

clipboard7

And here below is the code how “1880” is transformed to “2k” by framework code:

clipboard8

The reason why English version of CLDR file is loaded is the language setting of the browser.
UI5 runtime will use the first Language configured in browser as primary language for all subsequent language-specific configuration stuff load mechanism, as illustrated in line 67 below:

clipboard9

Finally the English version of CLDR file is loaded in line 718:

clipboard10

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