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

时间:2013-12-05 08:30:22

标签: javascript model-view-controller sapui5

我有一个带有单选模式的表和工具栏中的按钮可以删除所选行的视图。

虽然当我按下按钮时,它会删除所有行。

我的代码:

查看文件:

<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....

有什么想法吗?

3 个答案:

答案 0 :(得分:4)

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

答案 1 :(得分:1)

以下是如何执行此操作的示例。

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

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

-D

答案 2 :(得分:0)

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

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);