JavaScript中的子窗口与父窗口的互相调用问题
程序员文章站
2022-06-10 17:05:15
注意:要用open打开才行,如果用openmodal打开则会访问不到opener.
open的参数:
window.open('page.html','neww...
注意:要用open打开才行,如果用openmodal打开则会访问不到opener.
open的参数:
window.open('page.html','newwindow','height=100,width=400,top=0,left=0,toolbar=no,menubar=no,scrollbars=no,resizable=no,location=no,status=no')
参数说明
'page.html' 弹出窗口的文件名; 'newwindow' 弹出的新窗口的名字,非必须,可用空''代替;
height=100 高度; width=400 宽度; top=0 窗口距离屏幕上方的象素值; left=0 窗口距离屏幕左侧的象素值;
toolbar=no 是否显示工具栏,yes为显示; menubar,scrollbars 表示菜单栏和滚动栏;
resizable=no 是否允许改变窗口大小,yes为允许; location=no 是否显示地址栏,yes为允许;
status=no 是否显示状态栏内的信息(通常是文件已经打开),yes为允许;
1、从子窗口中往父窗口传值
如父页面有一个控制的id是choosedprovider,那么这样可以把值传给父页面:
opener.document.getelementbyid("choosedprovider").value="tom";
2、从父窗口传值给子窗口,如子窗口中有id为t的控件,此时可以用如下传值:
<script> var newwindow; function openwindow(url){ newwindow = window.open(“new.htm”, "", "width=400,height=300 "); } function changechild(){ newwindow.document.getelementbyid("t").value="我变了"; } </script>
3、子窗口关闭并刷新父口,这里有两种方式:
1) 子窗口关闭时关闭父窗口:
opener.location.reload(); window.close();
2) 父窗口去检测,子窗口是否已经关闭了,在设定的一段时间之后自动刷新:
<script> var newwindow; var timer; function openwindow(url) { newwindow = window.open(url, "", "width=400,height=300,resizable=yes"); timer = setinterval("updateafterclose()", 1000); } function updateafterclose() { //父窗口去检测子窗口是否关闭,然后通过自我刷新,而不是子窗口去刷新父窗口 if(newwindow.closed == true) { clearinterval(timer); self.location.reload(); // 主窗口刷新 return; } } </script>
4、父窗口关闭的时候关闭子窗口。这个就是用方法去检测父窗口的onunload事件:
<script> var newwindow; function openwindow(url) { newwindow = window.open(url, "", "width=400,height=300,resizable=yes"); } function closechild() { newwindow.close(); } </script>
在body加上onunload事件:
<body onunload="closechild()">
5、子窗口中关闭父窗口,这个功能可能相对要少用一点:
<script> function closeparent() { opener.close(); } </script> <input type=button value="关闭父窗口" onclick=closeparent()>
以上所述是小编给大家介绍的javascript中的子窗口与父窗口的互相调用问题,希望对大家有所帮助
推荐阅读
-
JavaScript中的子窗口与父窗口的互相调用问题
-
jquery、js调用iframe父窗口与子窗口元素的方法教程
-
JS与jQuery实现子窗口获取父窗口元素值的方法
-
winform子窗口调用父窗口的控件及方法-一般调用
-
总结JavaScript(Iframe、window.open、window.showModalDialog)父窗口与子窗口之间的操作
-
总结JavaScript(Iframe、window.open、window.showModalDialog)父窗口与子窗口之间的操作
-
javascript在父窗口iframe跨域操作子元素无法绑定子域下的function的解决办法 jquerybindlivedelegateiframe
-
jQuery获取父窗口与子窗口的iframe案例详解
-
JS获取父窗口与子窗口的iframe案例详解
-
JavaScript中的子窗口与父窗口的互相调用问题