UI5 setModel 的核心逻辑

updateBindings

_bindAggregation

mBindingInfos

_bindProperty

ClientPropertyBinding

oValue

_getValue

aBindings

为什么UI controlcall了setModel,传入了正确的json 数据之后,控件在runtime时仍然没有显示任何东西?

example:有一个table控件,items绑定如下:

UI5 setModel 的核心逻辑

某个table cell绑定信息如下:

UI5 setModel 的核心逻辑

通过setModel将如下的数据绑定到table上, ProductId在json数据里的值为HT-1020:

UI5 setModel 的核心逻辑

setModel的执行过程:

 

1. 处理最外层的items绑定,其path是xml view里指定的/LineItems


UI5 setModel 的核心逻辑


2. sPath提示该binding是table最外层的binding,oList为json data里table的两条行数据:

UI5 setModel 的核心逻辑

3. 依次处理table row里每个column的绑定:


UI5 setModel 的核心逻辑

从这里能看出,setModel进行数据绑定的过程中,也是一个把Model里json data对应的字段的实际内容写入到bindingInfo 这个抽象类的instance里的过程,setModel完全可以看成一个赋值过程:

UI5 setModel 的核心逻辑

如何判断setModel是否成功执行

 

setModel执行完后,检查调用setModel的control instance的oModels field,找出里面名字和调用setModel时传入的model name一致的字段( 如果调用setModel时没有传model name,则model name 为undefined ):

UI5 setModel 的核心逻辑


如果发现aBindings length 大于0,并且能够从每个item里看到item 绑定的路径信息和实际的值,就说明setModel成功执行了。

<img src=“https://user-images.githubusercontent.com/5669954/27379535-e0016f80-567b-11e7-8467-693544145178.png)

上一篇:将数据库设置为归档模式后,数据库出现停机


下一篇:where is os type and version determined for a ui5 html