我有表sap.ui.table.Table
,也有一个模型,其中一些记录具有链接,而有些则没有。我想在该列的sap.m.Link
组件中呈现该链接,并且当该记录中的链接不可用时,它应该呈现“未提供链接”。在列中的sap.m.Text
中。
由于sap.ui.table.Column
具有模板聚合,该模板聚合不支持绑定聚合,因为它仅支持0或1个控件。格式化程序在这里也适用。有什么方法可以根据模块数据在运行时更改列的内容?
我的模块数据是:
var data = [{
id : 1,
link : 'abc.com'
},
{
id : 2
},
{
id : 3,
link : 'pqr.com'
}]
我正在提供代码:
var link = new sap.m.Link({text : "{link}"});
var noLink = new sap.m.Text({text : "Link is not provided."});
var idColumn = new sap.ui.table.Column({
label : [new sap.m.Label({text : "ID"})],
template : [new sap.m.Text({text : "{id}"})]
});
var linkColumn = new sap.ui.table.Column({
label : [new sap.m.Label({text : "Link"})],
template : [??????]
});
var table = new sap.ui.table.Table({
columns : [idColumn, linkColumn]
});
var model = new sap.ui.model.json.JSONModel();
model.setData({items : data});
table.setModel(model);
table.bindRows("/items");
我想根据模块中的数据在link
行中添加noLink
和likColumn
。我该如何实现?
答案 0 :(得分:1)
可以使用formatter
例如:
new sap.m.Link({
width: "20em",
//editable: false,
//text: "{items>link}"
text: {
path: "items>link",
formatter: function(link){
if (link === undefined) return "Link is not provided"
return link;
}
}
});
...
oTable.addEventDelegate({
onAfterRendering: function(){
$('#idTable a:contains("Link is not provided")').removeClass("sapMLnk");
}
}, oTable);
更新:这是一个jsbin,其中包含您需要的完整示例: UPDATED example