单击右上角的关闭(x)按钮后,DOJO 对话框未第二次打开

Posted

技术标签:

【中文标题】单击右上角的关闭(x)按钮后,DOJO 对话框未第二次打开【英文标题】:DOJO dialog not opening second time after clicking close(x) button on the upper right corner 【发布时间】:2013-03-13 09:29:02 【问题描述】:

我的页面中有一个名为 EDIT 的对话框按钮。

第一次点击编辑按钮时,弹出编辑窗口。当我通过单击位于弹出窗口右上角的关闭 (x) 按钮关闭弹出窗口并再次单击编辑按钮时,弹出窗口没有出现(打开)。但是在单击位于同一“编辑”弹出窗口下方的“取消”和“应用”按钮并第二次单击“编辑”后,弹出窗口将打开。所以点击关闭按钮后出现问题,不允许我再次打开编辑窗口。

更新:

我发现代码(如下)不允许我第二次打开“编辑”对话框,我对其进行了评论。但是评论代码引起了另一个问题,即当我点击“取消”或“应用”按钮时,它会抛出以下错误,并且不允许我通过抛出相同的错误再次打开“编辑”按钮。

【问题讨论】:

尝试在 jsFiddle 上创建工作示例或仅发布代码的相关部分以获得一些 asnwer... 对不起。我删除了可能不相关的额外 .js 文件。 【参考方案1】:

您在关闭时销毁小部件 (destroyOnClose : true),因此无法在第二次尝试时打开它。

/*
 * Overload the _destroyOrHide method in rmt.NewModalPopup so 
 * that the popup will be destroyed instead of closed. (Close
 * doesn't remove the DOM node.)
 */

【讨论】:

我也尝试更改 (destroyOnClose : false)。即使这样,弹出窗口也没有第二次打开。 您是否单步执行了代码 (_destroyOrHide) 并验证它实际上没有破坏 idget? 当我单击关闭按钮时,甚至没有调用 _destroyOrHide 方法。相反,正在调用名为 close() 的方法。我在主屏幕中提到了方法定义作为更新。【参考方案2】:

在创建对话框之前,请添加以下代码:

if (dojo.byId('displayQualificationPane') != null) 
                        dojo.forEach(dijit.findWidgets(dojo.byId('displayQualificationPane')), function (w) 
                            w.destroyRecursive();
                        );
                    
                    dojo.destroy(dojo.byId('displayQualificationPane'));
                    if (dijit.byId('displayQualificationPane')) 
                        dijit.byId('displayQualificationPane').destroy();
                    

它会在每次创建之前销毁小部件。

【讨论】:

我试过了。不成功。编辑按钮没有第二次打开。 嘿..您需要添加用于销毁小部件的代码(您现在已经评论过)我猜。当您从 (x) 按钮关闭对话框后再次打开对话框时,您遇到了什么错误? 当我尝试再次打开“编辑”对话框时,出现错误“尝试使用 id==editQualificationsApply 注册小部件,但该 id 已注册”。 你能从 firebug 获取那个 (x) 按钮的 id .. 并在使用我共享的代码创建对话框之前将其销毁。【参考方案3】:

另一种技术,类似于 Himani 的建议,但可能更易于使用,是确保在调用 hide 函数后销毁对话框内容。这样,您在初始化组件时不必为此进行任何复杂的检查。

hide: function() 
    this.inherited(arguments);
    window.setTimeout( dojo.hitch( this, 'destroyRecursive' ), 500 );

甚至可能

aspect.after( dialog, 'hide', dojo.hitch( this, function() 
                      setTimeout( function() 
                          dialog.destroyRecursive();
                      , 500 );
              ));

【讨论】:

以上是关于单击右上角的关闭(x)按钮后,DOJO 对话框未第二次打开的主要内容,如果未能解决你的问题,请参考以下文章

模态对话框,点击右上角的X按钮关闭不了窗口么

如何在dojo Modaldialog中单击关闭按钮来捕获事件?

单击红色关闭 (x) 按钮和调用 .Close() 有啥区别?

如何从父关闭按钮单击事件打开的子对话框中关闭父对话框?

C# winForm程序窗体右上角X关闭按钮点击后 弹出提示文本 只有确定按钮点击后程序无法关闭

jquery-ui-dialog - 如何挂钩对话框关闭事件