如何向一个页面中的两个iframe传值

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了如何向一个页面中的两个iframe传值相关的知识,希望对你有一定的参考价值。

jsp页面子页面像父页面的iframe传值:
1:document.getElementById("ii").contentWindow 得到iframe对象后,就可以通过contentWindow得到iframe包含页面的window对象,然后就可以正常访问页面元素了;
2:$("#ii")[0].contentWindow  如果用jquery选择器获得iframe,需要加一个【0】;
3:$("#ii")[0].contentWindow.$("#dd").val() 可以在得到iframe的window对象后接着使用jquery选择器进行页面操作;
4:$("#ii")[0].contentWindow.hellobaby="dsafdsafsdafsdafsdafsdafsadfsadfsdafsadfdsaffdsaaaaaaaaaaaaa"; 可以通过这种方式向iframe页面传递参数,在iframe页面window.hellobaby就可以获取到值,hellobaby是自定义的变量;
5:在iframe页面通过parent可以获得主页面的window,接着就可以正常访问父亲页面的元素了;
6:parent.$("#ii")[0].contentWindow.ff; 同级iframe页面之间调用,需要先得到父亲的window,然后调用同级的iframe得到window进行操作;
实例代码:

<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"> 
<html> 
<head> 
<meta http-equiv="Content-Type" content="text/html; charset=utf-8"> 
<title>显示图表</title> 
<script src="/jquery-1.7.1.min.js" type="text/javascript"></script> 
<script type="text/javascript"> 
    var gg="dsafdsafdsafdsafsdaf"; 
    function ggMM()  
        alert("22"); 
     
    function callIframeMethod()  
        //document.getElementById("ii").contentWindow.test(); 
        $("#ii")[0].contentWindow.test(); //用jquery调用需要加一个[0] 
     
    function callIframeField()  
        alert($("#ii")[0].contentWindow.ff); 
     
    function callIframeHtml()  
        alert($("#ii")[0].contentWindow.$("#dd").val()); 
        //alert($("#ii")[0].contentWindow.document.getElementById("dd").value); 
        //alert($("#ii")[0].contentWindow.document.getElementById("dd").value);              
        
    function giveParameter()  
        $("#ii")[0].contentWindow.hellobaby="dsafdsafsdafsdafsdafsdafsadfsadfsdafsadfdsaffdsaaaaaaaaaaaaa"; 
     
</script> 
</head> 
<body> 
    <a href="#" onClick="giveParameter();">参数传递</a> 
    <a href="#" onClick="callIframeMethod();">调用子iframe方法</a> 
    <a href="#" onClick="callIframeField();">调用子iframe变量</a> 
    <a href="#" onClick="callIframeHtml();">调用子iframe组件</a></br>   
    <iframe id="ii" src="frame.htm" width="100%" frameborder="0"></iframe> 
    <iframe id="new" src="newFrame.htm" width="100%" frameborder="0"></iframe> 
</body> 
</html>

参考技术A jsp页面子页面像父页面的iframe传值:
1:document.getElementById("ii").contentWindow 得到iframe对象后,就可以通过contentWindow得到iframe包含页面的window对象,然后就可以正常访问页面元素了;
2:$("#ii")[0].contentWindow 如果用jquery选择器获得iframe,需要加一个【0】;
3:$("#ii")[0].contentWindow.$("#dd").val() 可以在得到iframe的window对象后接着使用jquery选择器进行页面操作;
4:$("#ii")[0].contentWindow.hellobaby="dsafdsafsdafsdafsdafsdafsadfsadfsdafsadfdsaffdsaaaaaaaaaaaaa"; 可以通过这种方式向iframe页面传递参数,在iframe页面window.hellobaby就可以获取到值,hellobaby是自定义的变量;
5:在iframe页面通过parent可以获得主页面的window,接着就可以正常访问父亲页面的元素了;
6:parent.$("#ii")[0].contentWindow.ff; 同级iframe页面之间调用

iframe父页面与子页面之间的传值问题

一、父页面给iframe中的子页面传值,把值写入子页面的文本框里

father.html

<script language="javascript" src="http://www.aspbc.com/js/jquery.js" type="text/javascript"></script> 
<script type="text/javascript"> 
function fuzhi() 

    $(‘#son‘).contents().find("#b").val("父页面传过来的值!");  

</script> 

 

<iframe id="son" name="son" src="son.html" width="400" height="200"></iframe><br /> 
<input type="button" value="给子页面表单中id为b的文本框赋值" onclick="fuzhi()" /> 

son.html

<form name="form2"><input type="text" name="b" id="b" /></form>

二、子页面如何调用父页面中的函数

father.html

<script language="javascript" src="http://www.aspbc.com/js/jquery.js" type="text/javascript"></script> 
<script type="text/javascript"> 
function fun() 

    alert(‘这是父页面中的函数弹出窗口哦!‘); 

</script>  
<iframe id="son" name="son" src="son.html" width="400" height="200"></iframe>

son.html

<script type="text/javascript"> 
function diaoyong() 
{     
    $(window.parent.fun());  //调用父页面函数 

</script> 
<form name="form2"> <input name="btn1" type="button" onclick="diaoyong()" value="调用父页面中的函数" /></form>

三、iframe中的子页给父页面传值

father.html

<script language="javascript" src="http://www.aspbc.com/js/jquery.js" type="text/javascript"></script> 
<div id="messagediv">test</div> 
<iframe id="son" name="son" src="son.html" width="400" height="200">
</iframe>

son.html

<script type="text/javascript"> 
function fuzhi() 

    $(window.parent.$("#messagediv").html("子页面赋过来的值")); 

</script> 
<form name="form2"><input name="btn1" type="button" onclick="fuzhi()" value="给父页中id为messagediv的元素赋值" /></form>

以上是关于如何向一个页面中的两个iframe传值的主要内容,如果未能解决你的问题,请参考以下文章

如何在不同iframe之间传值

两个jsp页面如何传值

asp 网页 iframe 子页如何向父页回传参数

js传值到iframe中

iframe如何传值给父iframe

jquery ui dialog怎么向子窗口传值