在 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,以便它显示在下拉列表中。