我解决了这个问题,通过添加行为不是模式,而是通过ModalWindow.setContent()
添加到模式的小部件。当我的小部件被添加到模式中时,mask div存在于DOM中,然后我可以成功连接一个click处理程序。
机智:
public static class CloseModalOnOutsideClickBehavior extends AbstractDefaultAjaxBehavior
{
private final ModalWindow modal;
public CloseModalOnOutsideClickBehavior(ModalWindow modal)
{
this.modal = modal;
}
@Override
protected void respond(AjaxRequestTarget target)
{
if (myConditionIsMet()) modal.close(target);
}
@Override
public void renderHead(IHeaderResponse response)
{
response.renderJavascriptReference("http://ajax.googleapis.com/ajax/libs/jquery/1.5.2/jquery.min.js");
response.renderJavascript("" +
"$(document).ready(function() {\n" +
" $('div.wicket-mask-dark').bind('click', function(evt) {\n" +
getCallbackScript() + "\n" +
" evt.preventDefault();\n" +
" });\n" +
"});", "closeModal");
}
}
请注意,我有点摇摇欲坠取决于有一个名为“检票面罩黑暗”类的模态窗口的面具;如果您更改ModalWindow
使用的CSS设置,则情况可能不是这种情况。