SAP UI5-无法从表中删除所选行

SAP UI5 - Cannot delete selected row from table

本文关键字:删除 UI5- SAP      更新时间:2024-03-12

我有一个视图,其中有一个具有单选模式的表,工具栏中有一个删除所选行的按钮。

不过当我按下按钮时,它会删除所有的行。

我的代码:

查看文件:

<template data-controller-name="myapplication.myview2">
    <div data-sap-ui-type="sap.ui.table.Table" id="tb1" data-width="100%" data-title="Person Table"></div>
</template>

控制器文件:

onInit: function() {
        try {
            var oTab = [
                        // the table content
                        ];
            var oToolbar = new sap.ui.commons.Toolbar();
            oToolbar.addItem(new sap.ui.commons.Button({text: "Delete selected row", 
                press: function() {
                    try {
                        var newTab = this.getParent().getParent();
                        var index = newTab.getSelectedIndex();
                        if (index == -1)
                            alert("No row selected");
                        else {
                            var currModel = newTab.getModel();
                            var selectedRow = newTab.getRows()[index];
                            newTab.removeRow(selectedRow);
                            currModel.setData({table: newTab});
                            newTab.bindRows("/table");                  
                        }
                    } catch (err) {
                        txt = "There was an error on this page.'n'n";
                        txt += "Error description: " + err.message + "'n'n";
                        txt += "Click OK to continue.'n'n";
                        alert(txt);
                    }
                }}));
            this.byId("tb1").setToolbar(oToolbar);
            this.byId("tb1").setVisibleRowCount(5);
            this.byId("tb1").setNavigationMode(sap.ui.table.NavigationMode.Paginator);
            // Columns definition should be HERE
            var oModel = new sap.ui.model.json.JSONModel();
            oModel.setData({table: oTab});
            this.byId("tb1").setModel(oModel);
            this.byId("tb1").bindRows("/table");
        } catch (err) {
            txt = "There was an error on this page.'n'n";
            txt += "Error description: " + err.message + "'n'n";
            txt += "Click OK to continue.'n'n";
            alert(txt);
        }
    },
// More functions....

有什么想法吗?

您需要从模型中移除行,而不是直接从表中移除。

这里有一个关于如何做到这一点的示例。

http://jsbin.com/yewula/1/edit

就像许多人建议的那样,我们应该把它从模型中删除。由于表已绑定到模型,因此表将相应地刷新。

-D

在删除按钮的按下功能中,获取有关表格的更多详细信息:

var tableIndex = newTab.getSelectedIndex();
var context = newTab.getContextByIndex(tableIndex);
var path = context.getPath();

在变量路径中,您将找到与表行索引相对应的数据索引。使用此数据索引可以从模型中删除该行。

currModel.oData.table.splice(data_index, 1);

之后,所需要的只是刷新模型,以向控件通知更改后的数据。而且,对于用户来说,如果表中的选择也被重置,那可能也很好。

currModel.refresh();
newTab.setSelectedIndex(-1);