1

我有以下代码

oTableEntry = this.getView().byId("oTable");
var count = oTableEntry._getRowCount();
var oTData;

for (var i = 0; i < count; i++) {
    oTData = oTableEntry.getContextByIndex(i).getObject();

oTData不包含所有列的值,即使它们出现在表中。我在这里做错了吗?

4

2 回答 2

2

我认为您正在尝试获取表格列及其每行的值。您可以这样做:

var oTable = this.getView().byId("oTable");//Get the table by Id    
var aItems = oTable.getAggregation("items");//get the items of the table
for (var i=0; i<aItems.length; i++) {
  var tableColumns = aItems[i].getAggregation("cells");     //Here tableColumns will    //have all the columns of the table rows. 
  var column1Value = tableColumns[1].getProperty("text");
}

于 2018-09-03T18:11:13.983 回答
2

希望您正在寻找相同的解决方案!

var oTable = sap.ui.getCore().byId("YourTableID");
if (oTable) {
 var oColumns = oTable.getColumns();//get all columnms
 var oRows = oTable.getItems();
 for (var r in  oRows) {
    var oRow = oRows[r];
    console.log(oRow.getBindingContext().getObject());//return the row data
 }
}
于 2018-09-04T05:57:56.607 回答