Use insertItem after bindAggregation in Sap.m.Select(在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。选择的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:在Sap.m中的bindAggregation之后使用insert Item。选择
基础教程推荐
- 使用 jQuery 在悬停时交换 DIV 类 2022-01-01
- 带角度的选项卡:仅使用 $http 在单击时加载选项卡 2022-01-01
- HTML5 画布调整为父级 2022-01-01
- 即使每次插入第一个输入的值不同,第二个输入仍显示相同的输入值 2022-01-01
- 从快速中间件中排除路由 2022-01-01
- CORS:当凭据标志为真时,无法在 Access-Control-Allow-Origin 中使用通配符 2022-01-01
- 在 Javascript 中使用 Fetch API 上传文件并显示进度 2022-01-01
- 逻辑运算符 ||在 javascript 中,0 代表 Boolean false? 2022-01-01
- 最佳动态 JavaScript/JQuery 网格 2022-01-01
- 当木偶师打开Chrome时,不能使用Chrome扩展 2022-01-01
