在 Sap.m.Select 中的 bindAggregation 之后使用 insertItem
Use insertItem after bindAggregation in Sap.m.Select
我是第一次在这里发帖。
我有一个 sap.m.Select 使用 "bindAggregation" 方法显示来自 oDataModel 的年份。
我的想法是在 Select 中创建一个额外的 Item 文本:"All Values" 和 Key:“*”,所以我尝试在 [= 之后使用 "insertItem" 22=],但我创建的项目没有出现在 Select 项目列表中,只有来自 oDataModel 的年份。
代码如下:
var yearSelectBox = this.getView().byId("idYearSelectBox");
yearSelectBox.setModel(new sap.ui.model.odata.ODataModel("../../../ui/WebContent/Kpi/services/dates.xsodata", true));
yearSelectBox.bindAggregation("items", "/Years", new sap.ui.core.Item({
key: "{YEAR}",
text: "{YEAR}"
}),0);
yearSelectBox.insertItem(new sap.ui.core.Item({
key: "*",
text: "All Values"
}));
我尝试在 bindAggregation 之前使用 insertItem,使用 itemIndex = -1, 0, 20,但没有任何改变。
不幸的是,您想要实现的目标 - 虽然对您有意义 - 在绑定的上下文中没有意义。当您将数据模型绑定到控件时,该控件的所有呈现都基于该模型。此外,任何更改通过。控件被推回模型 - 这使模型和控件保持同步。因此,一旦绑定到位,您就不能简单地将另一个项目添加到聚合中。绑定控制添加(更新和删除)哪些项目,而不是程序干扰。您有两个简单的选择(也许还有其他选择):将模型数据读入 JSON 模型,包括 All Values 下拉条目,然后将下拉控件绑定到 JSON 模型,或将 所有值 条目添加到基础 OData 数据库 table,以便它显示在下拉列表中。
我是第一次在这里发帖。
我有一个 sap.m.Select 使用 "bindAggregation" 方法显示来自 oDataModel 的年份。
我的想法是在 Select 中创建一个额外的 Item 文本:"All Values" 和 Key:“*”,所以我尝试在 [= 之后使用 "insertItem" 22=],但我创建的项目没有出现在 Select 项目列表中,只有来自 oDataModel 的年份。
代码如下:
var yearSelectBox = this.getView().byId("idYearSelectBox");
yearSelectBox.setModel(new sap.ui.model.odata.ODataModel("../../../ui/WebContent/Kpi/services/dates.xsodata", true));
yearSelectBox.bindAggregation("items", "/Years", new sap.ui.core.Item({
key: "{YEAR}",
text: "{YEAR}"
}),0);
yearSelectBox.insertItem(new sap.ui.core.Item({
key: "*",
text: "All Values"
}));
我尝试在 bindAggregation 之前使用 insertItem,使用 itemIndex = -1, 0, 20,但没有任何改变。
不幸的是,您想要实现的目标 - 虽然对您有意义 - 在绑定的上下文中没有意义。当您将数据模型绑定到控件时,该控件的所有呈现都基于该模型。此外,任何更改通过。控件被推回模型 - 这使模型和控件保持同步。因此,一旦绑定到位,您就不能简单地将另一个项目添加到聚合中。绑定控制添加(更新和删除)哪些项目,而不是程序干扰。您有两个简单的选择(也许还有其他选择):将模型数据读入 JSON 模型,包括 All Values 下拉条目,然后将下拉控件绑定到 JSON 模型,或将 所有值 条目添加到基础 OData 数据库 table,以便它显示在下拉列表中。