本篇内容主要讲解“Javascript如何在两个窗体之间传值”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Javascript如何在两个窗体之间传值”吧!
如我们新建窗体 FatherPage.htm:
<script type="text/javascript">
function OpenChildWindow(){
window.open('ChildPage.htm'); }
</script>
<input type="text" id="txtInput" />
<input type="button" value="OpenChild" onclick="OpenChildWindow()" />
然后在 ChildPage.htm 中即可通过 window.opener 来访问父窗体中的元素:
<script type="text/javascript">
function SetValue(){
window.opener.document.getElementById('txtInput').value =document.getElementById('txtInput').value;
window.close();}
</script>
<input type="text" id="txtInput" />
<input type="button" value="SetFather" onclick="SetValue()" />
其实在打开子窗体的同时,我们也可以对子窗体的元素进行赋值,因为 window.open 函数同样会返回一个子窗体的引用,因此 FatherPage.htm 可以修改为:
<script type="text/javascript">
function OpenChildWindow(){
var child = window.open('ChildPage.htm');
child.document.getElementById('txtInput').value =document.getElementById('txtInput').value; }
</script>
<input type="text" id="txtInput"/>
<input type="button" value="OpenChild" onclick="OpenChildWindow()" />
通过判断子窗体的引用是否为空,我们还可以控制使其只能打开一个子窗体:
<script type="text/javascript">
var childfunction OpenChildWindow(){
if(!child) child = window.open('ChildPage.htm');
child.document.getElementById('txtInput').value =document.getElementById('txtInput').value; }
</script>
<input type="text" id="txtInput" />
<input type="button" value="OpenChild" onclick="OpenChildWindow()" />
光这样还不够,当关闭子窗体时还必须对父窗体的child变量进行清空,否则打开子窗体后再关闭就无法再重新打开了:
<body onunload="Unload()">
<script type="text/javascript">
function SetValue(){
window.opener.document.getElementById('txtInput').value =document.getElementById('txtInput').value;
window.close();}
function Unload(){
window.opener.child=null;}
</script>
<input type="text" id="txtInput" />
<input type="button" value="SetFather" onclick="SetValue()" />
</body>
到此,相信大家对“Javascript如何在两个窗体之间传值”有了更深的了解,不妨来实际操作一番吧!这里是亿速云网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。