SimpleForm 上的 SAPUI5 数据绑定

wil*_*nde 4 data-binding odata sapui5 sap-fiori

我在尝试在简单表单上绑定数据时遇到问题。我正在使用模拟服务器并已成功将数据绑定到列表/表

我的 manifest.json 看起来像这样

"mock": {
    "dataSource": "mainService"
}
Run Code Online (Sandbox Code Playgroud)

我的模拟数据(UserDetailsS​​et.json)看起来像这样

[{
    "ID_PassNum": "cu001",
    "Title": "Mr",
    "Name": "Don",
    "Surname": "Ownery",
    "ResType": "SA",
    "Country": "South Africa"
}]
Run Code Online (Sandbox Code Playgroud)

我的 SimpleForm 字段看起来像这样

<Label text="Name" />
<Input value="{mock>/UserDetailsSet/0/Name}" />
<Label text="Surname" />
<Input value="{mock>/UserDetailsSet/0/Surname}"/>
Run Code Online (Sandbox Code Playgroud)

我错过了什么?

csc*_*uff 6

您似乎正在使用ODataModel. 在 ODataModels 中,针对集合/聚合的绑定不像使用 JSONModel 那样容易。您无法使用collection/index/property语法访问/绑定属性。

ODataModels 如何存储数据

如果您加载一个实体集,就像您UserDetailSet存储在 ODataModel 中的数据一样,看起来有点像这样:

{
  UserDetailSet('00001'): { ... },
  UserDetailSet('00002'): { ... },
  UserDetailSet('00003'): { ... },
  UserDetailSet('00004'): { ... }
}
Run Code Online (Sandbox Code Playgroud)

而“00001”等是实体键。如果您UserDetailSet在 ODataListBinding上创建聚合绑定,则将处理将上述数据转换为每个项目的上下文。

ODataModel 上的属性绑定

您的绑定必须如下所示:

<Label text="Name" />
<Input value="{mock>/UserDetailSet('00001')/Name}" />
<Label text="Surname" />
<Input value="{mock>/UserDetailSet('00001')/Surname}"/>
Run Code Online (Sandbox Code Playgroud)

ODataModel 上的动态属性绑定

或者 - 更动态一点 - 像这样绑定(注意:绑定现在是相对的,没有前导/):

<SimpleForm id="MyForm">
  <Label text="Name" />
  <Input value="{mock>Name}" />
  <Label text="Surname" />
  <Input value="{mock>Surname}"/>
</SimpleForm>
Run Code Online (Sandbox Code Playgroud)

bindElement在 SimpleForm 本身上动态使用:

this.getView().byId("MyForm").bindElement({
  path: "/UserDetailSet('"+ sUserID +"')",
  model: "MyOdataModelID",
  // use OData parameters here if needed
  parameters: {
    "expand": "UserAdress"
  },
  // react on binding events here
  events: {
    change: function (oEv) { },
    dataRequested: function (oEv) { },
    dataReceived: function (oEv) {}
  }
});
Run Code Online (Sandbox Code Playgroud)

BR克里斯