源码网商城,靠谱的源码在线交易网站 我的订单 购物车 帮助

源码网商城

js关闭模态窗口刷新父页面或跳转页面

  • 时间:2022-03-22 10:24 编辑: 来源: 阅读:
  • 扫一扫,手机访问
摘要:js关闭模态窗口刷新父页面或跳转页面
有两个窗口: A窗口(父),B窗口(模态) A窗口里有一个DATAGRID,一个按钮。 点击按钮时,弹出B窗口(模态)。在B窗口中添加数据,提交后,要求B窗口自关闭,然后刷新A窗口(父)
[u]复制代码[/u] 代码如下:
<script type="text/javascript"> function openSubWin() { window.showModalDialog('b.html', 'newwindow', 'height=500, width=400, top=0, left=0, toolbar=no, menubar=yes, scrollbars=yes,resizable=yes,location=no, status=no'); window.location.reload(); } </script>
弹出子窗体b.html , 当关闭子窗体时 触发父页面刷新 最近做物资系统的时候,又涉及到模态窗口的问题了,上次做的时候没遇到这次这么多东西,记下来吧 父窗口 js方法
[u]复制代码[/u] 代码如下:
function openwin(id){ var answer=window.showModalDialog("demand.do?method=queryBOM&mdid="+id+"&d="+escape(new Date()),window.self,"dialogWidth:700px;dialogHeight:620px:center:yes"); if(answer==1){ window.location.href = "demand.do?method=selmd&d="+escape(new Date()); //转到处理页面 //window.location.reload(); 刷新父窗口 //winow.location.reload(true); } }
加个escape(new Date()) 避免读取缓存,当然也可以在子窗口中,加入 <META HTTP-EQUIV="pragma" CONTENT="no-cache"> <META HTTP-EQUIV="Cache-Control" CONTENT="no-cache, must-revalidate"> 子窗口 js 方法:
[u]复制代码[/u] 代码如下:
function reVal(){ window.returnValue=1; //父窗口中 answer的值 window.close(); }
打开模态窗口之后,父窗口会一直等待子窗口返回个值,如果是表单提交或是button就执行reVal()方法 返回answer的值,window.returnValue=1 这个地方我测试了 好像只能返回String类型的,数组类型的不好使 在子窗口中使用 window.opener.location.reload(); 不好使,不试用于模态窗口,window.opern() 好使 还有个问题是:在模态窗口里form 提交会弹出新窗口,这个问题简单就在<head>里面加个<base target="_self"> 就可以搞定,注:我刚开始是不想通过form提交的,用js window.location.href 跳转到不同的action去处理,发现 <base target="_self"> 就不起作用了,似乎 <base target="_self"> 只是针对form action="" 才起作用,这个地方应该可以用iframe 去实现。
  • 全部评论(0)
联系客服
客服电话:
400-000-3129
微信版

扫一扫进微信版
返回顶部