js关闭模态窗口刷新父页面或跳转页面_Javascript教程-查字典教程网
js关闭模态窗口刷新父页面或跳转页面
js关闭模态窗口刷新父页面或跳转页面
发布时间:2016-12-30 来源:查字典编辑
摘要:有两个窗口:A窗口(父),B窗口(模态)A窗口里有一个DATAGRID,一个按钮。点击按钮时,弹出B窗口(模态)。在B窗口中添加数据,提交后...

有两个窗口: A窗口(父),B窗口(模态)

A窗口里有一个DATAGRID,一个按钮。

点击按钮时,弹出B窗口(模态)。在B窗口中添加数据,提交后,要求B窗口自关闭,然后刷新A窗口(父)

复制代码 代码如下:

<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方法

复制代码 代码如下:

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 方法:

复制代码 代码如下:

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 去实现。

相关阅读
推荐文章
猜你喜欢
附近的人在看
推荐阅读
拓展阅读
  • 大家都在看
  • 小编推荐
  • 猜你喜欢
  • 最新Javascript教程学习
    热门Javascript教程学习
    编程开发子分类