在Sap.m中的bindAggregation之后使用insert Item。选择 [英] Use insertItem after bindAggregation in Sap.m.Select

查看:29
本文介绍了在Sap.m中的bindAggregation之后使用insert Item。选择的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

是我第一次在这里发帖。

我有一个Sap.m.Select,它使用"bindAggregation"方法显示oDataModel中的年份。

我的想法是在Select With Text:"All Values"和Key:"*"中创建一个额外的项目,因此我尝试在"bindAggregation"之后使用"insert tItem",但我创建的项目没有出现在项目的选择列表中,只显示了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之前使用insert Item,以使用itemIndex=-1,0,20,但没有任何更改。

推荐答案

不幸的是,您试图实现的目标-虽然对您有意义-在绑定上下文中没有意义。将数据模型绑定到控件后,该控件的所有呈现都将基于该模型。此外,任何通过。控件被推回到模型-这使模型和控件保持同步。因此,一旦绑定就位,您就不能简单地将另一个项目添加到聚合中。绑定控制添加(更新和删除)哪些项,而不是编程干扰。您有两个简单的选择(可能还有其他选项):将模型数据读取到JSON模型中,包括All Values下拉项,然后将下拉控件绑定到该JSON Model,或者将All Values项添加到底层OData数据库表中,使其显示在下拉列表中。

这篇关于在Sap.m中的bindAggregation之后使用insert Item。选择的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆