我有一个网格,其中包含使用 ExtJS 7.2 上的现代材料主题的商店的记录。我想从这个视图中创建多个浮动的、可拖动的窗体,但是当我拖动窗体时,关闭它会在窗体所在的位置留下一个空白区域,从而遮挡背景。这是formpanel的来源。
onItemClick: function (grid,rowIndex,e) {
var record = grid.getStore().getAt(rowIndex);
var form = Ext.create({
xtype: 'formpanel',
id: `${record.id}_form_${record.get('blah')}`,
title: `Invoice ${record.get('blah')}`,
floating: true,
closable: true,
centered: true,
draggable: true,
shadow: true,
width:300,
height:window.innerHeight*0.8,
scrollable: true,
modal: null,
items: [
{
xtype: 'textfield',
name: 'Blah',
label: 'Blah',
value: record.get('blah'),
},
{
xtype: 'toolbar',
docked: 'bottom',
items: [{
xtype: 'button',
text: 'Save',
ui: 'raised round',
iconCls: 'x-fa fa-save',
handler: function() {
var theform = this.up('formpanel').getFields();
record.set(
{
'blah': theform['Blah'].getValue(),
}
);
this.up('formpanel').destroy();
}
},'->', {
xtype: 'button',
text: 'Cancel',
ui: 'raised round',
iconCls: 'x-fa fa-close',
handler: function() {
this.up('formpanel').destroy();
},
}]
}
]
});
Ext.Viewport.add(form);
}
有没有人有这个问题的经验?我尝试过使用自定义的 Ext.drag.Source 对象,但到目前为止没有成功。当我尝试关闭已拖动的窗体面板时,出现错误:
TypeError:Node.replaceChild 的参数 1 不是对象。
任何帮助,将不胜感激。