关于sap:SAP-UI5-setProperty-的执行逻辑单步调式和分析

39次阅读

共计 1761 个字符,预计需要花费 5 分钟才能阅读完成。

依照 Jerry 这篇文章介绍的代码,运行之后,给类型为 sap.ui.model.type.Currency 的字段设置一个非 number 类型的值之后,触发该数据类型自带的数据校验机制,显示 Enter a number 的谬误音讯。

SAP UI5 利用开发教程之四十六 – 应用 Message Manager 实现开箱即用的验证 (Validation) 信息抛出

本文介绍 SAP UI5 ManagedObjectsetProperty 办法的执行原理。

首先明确,什么是 ManagedObject

托管属性示意 ManagedObject 的状态。它们能够存储简略数据类型(如“字符串”或“整数”)的单个值。它们具备名称(例如“size”)和获取以后值(getSize)或设置新值(setSize)的办法。当通过调用 setter 批改属性时,ManagedObject 被标记为有效。能够应用 #bindProperty 办法将托管属性绑定到 sap.ui.model.Model 中的属性。对模型属性的更新将主动反映在托管属性中,并且 – 如果 TwoWay 数据绑定处于活动状态,则对托管属性的更改将反映在模型中。能够通过调用 #unbindProperty 删除现有绑定。

当 input 控件失去 focus 之后,触发 onsapfocusleave,这个办法调用 onChange

传入的输出参数,event 类型为 sapfocusleave

如果以后最新的值和之前的值 getLastValue() 不相等,则调用 this.setValue

Input.setValue 调用 InputBase.setValue:

setValue 最终调用 setProperty,属性名称为 value

正式进入 setProperty 办法,首先从 mProperties 里失去批改之前的值:

而后进行 validateProperty

validateProperty 外部,首先从 this.getMetadata().getManagedProperty(sPropertyName) 读取该 value 属性的 元数据

对于 SAP UI5 控件的元数据设计,请参考我这篇文章:

深刻学习 SAP UI5 框架代码系列之四:SAP UI5 控件的元数据实现。

取得 string 类型对象:

类型对象由一系列函数组成:

执行 normalize 操作:

将这个不非法的 value,设置到 this.mProperties[sPropertyName] 中。

进行双向绑定的逻辑解决:this.updateModelProperty

拿到绑定对象:

进入双向绑定的解决分支:

if (oBinding && oBinding.getBindingMode() == BindingMode.TwoWay) {
                oBindingInfo.skipPropertyUpdate++;
                SyncPromise.resolve(oValue).then(function(oValue) {return oBinding.setExternalValue(oValue);
                }).then(function() {
                    oBindingInfo.skipPropertyUpdate--;
                    return oBinding.getExternalValue();}).then(function(oExternalValue) {if (oValue != oExternalValue) {that.updateProperty(sName);
                    }
                    handleSuccess();}).catch(function(oException) {
                    oBindingInfo.skipPropertyUpdate--;
                    handleException(oException);
                }).unwrap();

SyncPromise.resolve(oValue).then(function(oValue) {return oBinding.setExternalValue(oValue);
                })

CompositeBinding.js 外部,外围逻辑是第 325 行的代码:

that.oType.parseValue(oValue, that.sInternalType, aCurrentValues);

调用 outputFormat 进行输出值的解析工作:

正文完
 0