从响应式弹出窗口的事件函数中调用来自控制器的函数

Call function from controller from within event function of a responsivepopup

我有一个包含 'Delete' 模式列表的响应式弹出窗口。 当我点击删除一个项目时,按下时调用一个函数。 使用此函数 'this' 是 oList,oEvent.oSource 也是 oList。 在事件函数中,我需要在我的控制器中调用一个函数。 我找不到引用我的控制器的方法,甚至不使用 sap..core..byId("Detail") 甚至整个命名空间。 我尝试从 oEvent.oSource.getParent().getParent() 走上 elemnt 树,然后调用 .getController() 但这是死胡同。

        handlePressViewSelection: function(oEvent) {
        var oResourceBundle = this.getResourceBundle();

        //create the list
        var oList = new sap.m.List({
            mode: "Delete",
            delete: this.handleDeleteSelectionItem
        });

        oList.setModel(this._oSelectedTrainingsModel);

        var oItemTemplate = new sap.m.StandardListItem({
            title : "{Title}",
            description : "{=${Begda} ? ${Type} - { path: 'Begda', type: 'sap.ui.model.type.Date', formatOptions: { style: 'medium' }} : ${Type}}",
            icon : "{icon}",
            iconInset : false
        });

        oList.bindAggregation("items", {
            path: "/",
            template: oItemTemplate,
            type: "Active"
        });

        var oBeginButton = new sap.m.Button({
            text: "Action1",
            type: sap.m.ButtonType.Reject,
            press: function(){
                oResponsivePopover.setShowCloseButton(false);
            }
        });
        var oEndButton = new sap.m.Button({
            text: "Action2",
            type: sap.m.ButtonType.Accept,
            press: function(){
                oResponsivePopover.setShowCloseButton(true);
            }
        });

        var oResponsivePopover = new sap.m.ResponsivePopover({
            placement: sap.m.PlacementType.Bottom,
            title: "",
            showHeader: false,
            beginButton: oBeginButton,
            endButton: oEndButton,
            horizontalScrolling: false,
            content: [
                oList
            ]
        });

        oResponsivePopover.openBy(oEvent.oSource);
    },

        handleDeleteSelectionItem: function(oEvent) {
        var oListItem = oEvent.getParameter('listItem');
        var oList = oListItem.getParent();
        var path = oListItem.getBindingContext().sPath;
        oList.getModel().getData().splice(parseInt(path.substring(1)), 1);
        oList.removeItem(oEvent.getParameter('listItem'));
        oList.getParent().getParent().getController()._updateViewSelectionButtonText(); //--> BROKEN
    },

当您从片段实例化弹出窗口时,您可以指定 "a Controller to be used for event handlers in the Fragment"(参见 https://sapui5.hana.ondemand.com/#docs/api/symbols/sap.ui.html#.xmlfragment

例如:

onOpenResponsivePopover : function(oEvent) {

    if (!this._oResponsivePopover) {
        // adding 'this' makes sure you specify the current controller to be used for event handlers 
        this._oResponsivePopover = sap.ui.xmlfragment("namespace.to.your.popoverfragment", this); 
        this.getView().addDependent(this._oResponsivePopover);
    }

    this._oResponsivePopover.openBy(oEvent.getSource());
},