我有一个代码如下:
Ext.Msg.prompt( Translation.RefusalMessageBoxTitle, "",
function(btn, text, cfg ){
if(btn == 'ok' && Ext.isEmpty(text)) {
var newMsg = '<span style="color:red;" class="error">' + Translation.RefusalMessageBoxEmpty + '</span>';
Ext.Msg.show(Ext.apply({}, { msg: newMsg }, cfg));
}else if( btn !== 'ok' ){
return;
}else if( btn == 'ok' ){
this.sendRefusalAnswer( methodName, text, "reject", Constant.DocumentStatus.REFUSED, me.selectedDocument.get('id'));
}
}, this, true, '' );
现在mz的问题是
var newMsg = '<span style="color:red;" class="error">' + Translation.RefusalMessageBoxEmpty + '</span>';
Ext.Msg.show(Ext.apply({}, { msg: newMsg }, cfg));
部分代码被执行,但随后盒子非常关闭......我怎么能阻止这个?任何想法?
编辑:
仅在EXTJS 4.2版本上发生这种情况 建设日期:2013-03-11 22:33:40(aed16176e68b5e8aa1433452b12805c0ad913836)仅限!!!!!
版本 建设日期:2013-05-16 14:36:50(f9be68accb407158ba2b1be2c226a6ce1f649314) 工作得很好° - °
答案 0 :(得分:0)
不要使用Ext.Msg
单例,而是使用常规窗口或自己创建多个Ext.window.MessageBox
实例。单例本身就是一个窗口,所有对alert
,confirm
,prompt
等的调用都会共享该组件,因此无法在该窗口中显示多个窗口。同一时间。
答案 1 :(得分:0)
我将其转换为消息对象:
Ext.Msg.show({
title: Translation.RefusalMessageBoxTitle,
minWidth: this.minPromptWidth,
buttons: Ext.Msg.OKCANCEL,
callback: function(btn, text, cfg ){
if(btn == 'ok' && Ext.isEmpty(text)) {
var newMsg = '<span style="color:red;" class="error">' + Translation.RefusalMessageBoxEmpty + '</span>';
Ext.Msg.show(Ext.apply({}, { msg: newMsg }, cfg));
}else if( btn !== 'ok' ){
return;
}else if( btn == 'ok' ){
this.sendRefusalAnswer( methodName, text, "reject", Constant.DocumentStatus.REFUSED, me.selectedDocument.get('id'));
}
},
scope:this,
multiline: true,
});
但仍然无法弄清楚如何阻止它关闭我_°
答案 2 :(得分:0)
好的我发现了......该死的构建版本在mz构建机器上是不同的。
我在当地有
建造日期:2013-03-11 22:33:40(aed16176e68b5e8aa1433452b12805c0ad913836)
在mz测试机器上我们有
建造日期:2013-05-16 14:36:50(f9be68accb407158ba2b1be2c226a6ce1f649314)
在我当地它不起作用......但是在测试机上它没有问题...... 3个月! WTF!