showModalDialog浏览器兼容问题

碰到的问题:

注意:在子窗口中如果需要提交页面为了兼容ie需要加入<base target="_self"> ie才会在当前对话框中打开页面而不是打开新页面

当使用showModalDialog来进行查询用户,然后返回用户信息到之前页面时,如果dialog中需要刷新,查询或者分页(及dialog需要重新发请求的情况下,刷新后直接通过<a href="javascript:;window.returnValue=‘${id}:${customerName}‘;window.close();">这种形式返回值在ff中有用,在chrome中没用。)

以下是解决chrome浏览器该问题的解决方法。

宁外还有一个问题,就是ie和(chrome、ff)对<base href="<%=basePath%>">的理解不同。

1、打开弹出窗口时把 window 作为第二个参数传入。

 var result = window.showModalDialog(url, window, "dialogWidth=" + width + "px;dialogHeight=" + height + "px;resizable:yes;")

 if (typeof (result) == ‘undefined‘) {

         result = window.ReturnValue;

     }

     return result;

2、在弹出窗口中,执行如下JS,以接收传入的window

 if (typeof (window.opener) == ‘undefined‘) window.opener = window.dialogArguments;

这一行不加也行。

 

3、弹出窗口关闭前,调用如下JS赋返回值

 window.retureValue = vals;

        if (window.opener && window.opener != null)

                window.opener.ReturnValue = vals;

         window.close();

showModalDialog浏览器兼容问题

上一篇:map/reduce 下ArrayWritable 的使用


下一篇:zoj 1004 Anagrams by Stack