有兩個窗口: 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 去實現。