SAP UI5 日期类型 sap.ui.model.type.Date 的解析格式问题分析

我开发了一个 SAP UI5 应用,使用了数据类型 sap.ui.model.type.Date,并且指定了显示格式 pattern 为:yyyy-MM-ddTHH:mm:ss

SAP UI5 日期类型 sap.ui.model.type.Date 的解析格式问题分析_第1张图片

这个字段绑定的数据源的值为:2015-04-01T01:20:59

我期望在 SAP UI5 上显示的格式为 某年-某月-某日-T-小时-分-秒,但是最后的显示效果如下图:April 1,2015

SAP UI5 日期类型 sap.ui.model.type.Date 的解析格式问题分析_第2张图片

本文介绍如何分析这个显示格式的问题。

我们在 Chrome 开发者工具里找到 sap.ui.model.type.Date 的实现文件地址:

sap/ui/model/type/Date.js
SAP UI5 日期类型 sap.ui.model.type.Date 的解析格式问题分析_第3张图片

首先在函数 Date1.prototype.formatValue 设置断点,观察到字符串类型的原始值,已经成功传入该函数了:

SAP UI5 日期类型 sap.ui.model.type.Date 的解析格式问题分析_第4张图片

sInternalType 的值:string

SAP UI5 日期类型 sap.ui.model.type.Date 的解析格式问题分析_第5张图片

string 类型的 PrimitiveType 值就为其本身。

该逻辑定义在如下函数里:

SimpleType.prototype.getPrimitiveType = function (sInternalType) {
        // Avoid dealing with type objects, unless really necessary
        switch (sInternalType) {
            case "any":
            case "boolean":
            case "int":
            case "float":
            case "string":
            case "object":
                return sInternalType;
            default:
                var oInternalType = DataType.getType(sInternalType);
                return oInternalType && oInternalType.getPrimitiveType().getName();
        }
    };

从模型中拿到格式数据的模板:

SAP UI5 日期类型 sap.ui.model.type.Date 的解析格式问题分析_第6张图片

比如一周七天的缩写单词,存储在 aDaysAbbrev 里:
SAP UI5 日期类型 sap.ui.model.type.Date 的解析格式问题分析_第7张图片

一年 12 个月的单词,存储在 aMonthsWide 里:
SAP UI5 日期类型 sap.ui.model.type.Date 的解析格式问题分析_第8张图片

进入 parse 函数内部,Calendar type 为:Gregorian,意思是阳历

SAP UI5 日期类型 sap.ui.model.type.Date 的解析格式问题分析_第9张图片

Calendar type 为枚举值,所有支持的 calendar 类型如下图所示:

SAP UI5 日期类型 sap.ui.model.type.Date 的解析格式问题分析_第10张图片

格式化数组的值:aFormatArray
SAP UI5 日期类型 sap.ui.model.type.Date 的解析格式问题分析_第11张图片

已经成功解析出 2015年4月2日了:

SAP UI5 日期类型 sap.ui.model.type.Date 的解析格式问题分析_第12张图片

开始解析:T01:20:30

SAP UI5 日期类型 sap.ui.model.type.Date 的解析格式问题分析_第13张图片

所有可能的日期分隔符

\u002d\u007E\u2010\u2011\u2012\u2013\u2014\ufe58\ufe63\uff0d\uFF5E

SAP UI5 日期类型 sap.ui.model.type.Date 的解析格式问题分析_第14张图片

Dateformat.js 函数的 _parse 函数的返回值,已经观察到小时,分和秒已经成功解析了。所以问题没有出在解析,而是在值的显示上。

SAP UI5 日期类型 sap.ui.model.type.Date 的解析格式问题分析_第15张图片

最后返回的值:Thu Apr 02 2015 01:20:30 GMT+0800 (China Standard Time

SAP UI5 日期类型 sap.ui.model.type.Date 的解析格式问题分析_第16张图片

更多Jerry的原创文章,尽在:"汪子熙":
SAP UI5 日期类型 sap.ui.model.type.Date 的解析格式问题分析_第17张图片

你可能感兴趣的:(SAP UI5 日期类型 sap.ui.model.type.Date 的解析格式问题分析)