1

我的页面标题上有一个首选项链接,它打开一个模式窗口(它用于修改用户首选项,如名称或密码)。

在取消按钮上,我关闭了这个窗口,但是当我试图重新打开它时,我遇到了这个 JS 错误:

el.addCls.apply(el, arguments);

我是使用关闭此窗口的好方法还是问题出在其他地方?

这是我的代码:

// My window definition
Ext.define('jnotes.window.UserPreferences', {
    extend: 'Ext.window.Window',
    layout: 'fit',
    modal: true,
    renderTo: Ext.getBody(),
    title: "<s:text name='user.preferences' />",
    items: new Ext.form.Panel({
        bodyPadding: 5,
        waitMsgTarget: true,
        method: 'POST',

        fieldDefaults: {
            labelAlign: 'right',
            labelWidth: 85,
            msgTarget: 'side'
        },
        defaultType: 'textfield',
        items: [{
            ... // my fields
        }],
        buttons: [{
            text: "<s:text name='action.save'/>",
            handler: function() {
                this.up('form').fireEvent('validate');
            },
        }, {
            text: "<s:text name='action.cancel'/>",
            handler: function() {
                this.up('form').fireEvent('cancel');
            }
        }]
    })
});

var preferencesWindow = null;

// Open my window
function displayPreferences() {
    preferencesWindow = Ext.create('jnotes.window.UserPreferences');
    var form = preferencesWindow.down('form');
    form.addListener('validate', this.saveUser, this);
    form.addListener('cancel', function() {
        preferencesWindow.close();
        preferencesWindow = null;
    }, this);
    form.load({
        ... // Loading data
    });
    preferencesWindow.show();
};
4

2 回答 2

6

您定义类的方式是创建表单并在类的所有实例之间共享。当您第一次销毁窗口时,表单也会随之销毁,这就是它的结束。

相反,您应该: a) 指定表单配置对象:

items: {
    xtype: 'form',
    // ....
}

b) 在 initComponent 方法中指定表单,使其绑定到该实例:

Ext.define('MyFoo', {
    initComponent: function(){
        this.items = new Ext.form.Panel(...);
        this.callParent();
    }
});
于 2012-07-08T10:40:03.057 回答
6

另一个可能解决您的问题的解决方案是在窗口配置中指定 closeAction:

closeAction: 'hide'

更多来自 Extjs Docs 关于 closeAction 的内容:

单击关闭标题工具时要执行的操作:

可能的值:

'destroy' : remove the window from the DOM and destroy it and all descendant Components. The window will not be available to be redisplayed via the show method.
'hide' : hide the window by setting visibility to hidden and applying negative offsets. The window will be available to be redisplayed via the show method.

默认情况下,关闭操作值为销毁。

于 2012-09-18T10:06:07.150 回答