单击右上角的关闭(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 对话框未第二次打开的主要内容,如果未能解决你的问题,请参考以下文章
如何在dojo Modaldialog中单击关闭按钮来捕获事件?
单击红色关闭 (x) 按钮和调用 .Close() 有啥区别?