Extjs 6:添加模态窗口不会屏蔽tbar和header

时间:2015-09-28 08:34:55

标签: javascript extjs extjs6

我有一个视图作为我的网格的容器。 该视图拥有一个tbar和一个标题。

当我添加模态窗口时,标题和tbar不会被屏蔽。

主视图:

Ext.define('myApp.view.customer.MyMain', {
    extend: 'Ext.panel.Panel',
    xtype: 'hlx-customermain',

    controller: 'maintoolbar',

    plugins: 'viewport',
    header: {
        xtype: 'myheader'
    },
    tbar: {
        xtype: 'mytoolbar'
    },

    items: [
        {
            xtype: 'mygrid'
        }
    ]


});

网格(使用控制器添加窗口)

    Ext.define('myApp.view.customer.MyGrid', {
        extend: 'Ext.grid.Panel',
        xtype: 'mygrid',

        tbar: {
            xtype: 'mygridtoolbar'
        },

        controller: 'mygrid',

        store: 'MyGridStore',

        columns: [
        ...
        ]

    });

ViewController的功能

onCustomerAddClick: function () {
        var me = this,
            addCustomerWindow = me.lookupReference('addCustomerWindow');

        if (!addCustomerWindow) {
            addCustomerWindow = new myApp.view.customer.AddCustomer();

            me.getView().ownerCt.add(addCustomerWindow);
        }

        addCustomerWindow.show();
    }

我甚至很难将它添加到ownerContainer - 这是MyMain类 - tbar和标题都没有被屏蔽。 看到这个小提琴,亲自体验错误:https://fiddle.sencha.com/#fiddle/uih

1 个答案:

答案 0 :(得分:1)

您不必将其添加到其所有者或其他任何地方。就这样做:

onAddCustomerClick: function () {
    /*var me = this,
        myWindow = me.lookupReference('myWindow');

    if (!myWindow) {
        myWindow = new MyWindow();
        me.getView().ownerCt.add(myWindow);
    }

    myWindow.show();*/
    var myWindow = Ext.create('MyWindow');

    myWindow.show();
}