如何在不同iframe之间传值
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了如何在不同iframe之间传值相关的知识,希望对你有一定的参考价值。
参考技术A 如何在不同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页面之间调用
关于使用iframe的父子页面进行简单的相互传值
当一个页面使用了iframe作为嵌套时,如何想要将父页面的数据传给iframe子页面,那iframe所指向的呢个子页面是怎么获取呢,又或者子页面的数据要给父页面使用,那么父页面又如何获取子页面的数据呢?下面根据这种情况作了一个简单的demo案例:
父页面是parentPage.html,子页面是childPage.html。
1、情况一:父页面获取子页面传入的数据(子页面给父页面传值)
父页面:
//获取子页面传入的数据 function GetChildValue(obj) document.getElementById(‘texts‘).innerText = obj;
子页面:
//给父页面传数据 var txt = ‘我是子界面主动传值给父界面的数值‘; parent.GetChildValue(txt); //GetValue是父界面的Js 方法
2、情况二:子页面获取父页面的数据(父页面给子页面传值)
父页面:
//给子页面传入数据 function toChildValue() var txt = ‘这是父页面给子页面的数据‘; return txt;
子页面:
//获取父页面传来的数据 var getParentVule = window.parent.toChildValue(); console.log(getParentVule)
具体传值的数据根据自己的项目要求修改,下面放上两个页面的完整代码:
父页面parentPage.htm
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>父页面</title> <style type="text/css"> .box width: 600px; height: 400px; margin: 10px auto; h3 font-size: 16px; .cont width: 100%; .cont h4 font-size: 14px; .cont #texts width: 100%; line-height: 22px; font-size: 13px; color: #2E2D3C; iframe /*只是隐藏,但任然保留DOM结构*/ visibility: hidden; </style> </head> <body> <div class="box"> <h3>这是父页面</h3> <div class="cont"> <h4>这是从子页面传入的数据:</h4> <div id="texts"></div> <iframe src="childPage.html" width="1px" height="1px" class="myIframe" name="myIframe"></iframe> </div> </div> <script type="text/javascript"> //获取子页面传入的数据 function GetChildValue(obj) document.getElementById(‘texts‘).innerText = obj; //给子页面传入数据 function toChildValue() var txt = ‘这是父页面给子页面的数据‘; return txt; </script> </body> </html>
子页面childPage.html
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>子页面</title> <style type="text/css"> .box width: 600px; height: 400px; margin: 10px auto; h3 font-size: 16px; </style> </head> <body> <div class="box"> <h3>这是子页面</h3> </div> <script type="text/javascript"> //给父页面传数据 var txt = ‘我是子界面主动传值给父界面的数值‘; parent.GetChildValue(txt); //GetValue是父界面的Js 方法 //获取父页面传来的数据 var getParentVule = window.parent.toChildValue(); console.log(getParentVule) </script> </body> </html>
以上是关于如何在不同iframe之间传值的主要内容,如果未能解决你的问题,请参考以下文章