ExtJS - 如何在普通面板上居中一个表单面板

3
我是使用extjs并尝试解决一个简单问题: 我有一个固定宽度的表单。我想在一个普通的Ext.Panel中居中这个表单。 我试图通过“css方式”实现这个目标-将左右边距设置为“auto”。 但是这不起作用,似乎边距被忽略了。 代码如下:
var curStateForm = new Ext.FormPanel({
    title:'test',
    width:300,
    bodyStyle:'margin:5px auto 0 auto',
    items: [edIst, edAdjust, edSumme]
});   


var testPanel = new Ext.Panel({
    width: '100%',
    frame:true,
    items: [curStateForm]
});  
7个回答

17

在 Ext 4 中,这对我非常有效。

可用于任何容器。

    layout: {
        type: 'vbox',
        align: 'center',
        pack: 'center'
    },
    items: [{
        title: 'Centered Panel',
        width: 200,
        height: 200
    }]

3
    style: {
        marginLeft: 'auto',
        marginRight: 'auto'
    },

2
我刚刚对面板进行了这个操作。
listeners: {
    afterlayout : function(container, layout, eOpts) {
    panel.center();
    }
}

对我很有帮助。


1

在面板中:

bodyStyle: "padding: 15px;"  // may also be only padding-left/right

1
例如,我使用这个布局:
Ext.layout.AbsoluteCenterLayout = Ext.extend(Ext.layout.ContainerLayout, {
    monitorResize:true,
    onLayout : function(ct, target){
        Ext.layout.AbsoluteCenterLayout.superclass.onLayout.call(this, ct, target);
        if(!this.container.collapsed){
            var sz = (Ext.isIE6 && Ext.isStrict && target.dom == document.body) ? target.getViewSize() : target.getStyleSize();
            this.setItemSize(this.activeItem || ct.items.itemAt(0), sz);
        }
    },
    setItemSize : function(item, size){
        if(item && size.height > 0){ // display none?
            formEl = item.getEl();
            var widthCenter = (size.width/2)-(formEl.getWidth()/2);
            var heightCenter = (size.height/2)-(formEl.getHeight()/2);
            formEl.setStyle({
                left: widthCenter+'px',
                top: heightCenter+'px',
                position: 'absolute',
            });
        }
    }
});
Ext.Container.LAYOUTS['absolutecenter'] = Ext.layout.AbsoluteCenterLayout;

我的表单:

    Viewport = new Ext.Viewport({
                renderTo: Ext.getBody(),
                layout: 'border',
                items: [{
                    region: 'center',
                    xtype: 'panel',
                    layout: 'absolutecenter',
                    baseCls: 'x-plain',
                    items:[{
                        id: 'form',
                        formId: 'admin-loginform',
                        xtype: 'form',
                        title: 'Authentication',
                        iconCls: 'admin-wnd-authentication',
                        frame: true,
                        autoHeight: true,
                        width: 270,
                        defaultType: 'textfield',
                        labelAlign: 'right',
...

1

你看过这个示例吗?看看“自定义布局/居中”下面的例子。

编辑:在Ext 3中,那个示例是最好的选择。现在在Ext 4中,最好在外部容器上使用vbox布局,并像A1rPun的答案中所示进行居中对齐。


谢谢,我没有找到那个,但我认为那就是我要找的东西 ;) - Ben
1
这个页面非常糟糕,一半的代码片段都不能正常工作,并且它们不代表屏幕上的内容! - IceGras
示例网址已失效。 - István

0

请在面板中尝试以下操作:

style: {
    "margin-left": "auto",
            "margin-right": "auto"
       }, 

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接