js调用父框架函数

if (window.parent && window.parent.frames["frame_main"]) {
alert(window.parent.frames["frame_main"]);
window.parent.frames["frame_main"]..location.reload();
}else
{
window.parent.frames.item("frame_main").location.reload();
}

if (window.parent && window.parent.frames["frame_main"]) {
alert(window.parent.frames["frame_main"]);
window.parent.frames["frame_main"].location.reload();
}
else if (window.parent && window.parent.frames.item("frame_main")) {
window.parent.frames.item("frame_main").location.reload();
}
//刷新父窗口
window.parent.frame_main.location.reload();

iframe父子兄弟之间调用传值(contentWindow && parent)

学习一个知识点最好的方法就是自己动手去的实现一些简单的helloworld,虽然可以在网上可以找到很多总结,但自己实现的过程才是自己的,期间遇到问题并解决问题的过程也会让自己记忆理解更加深刻。

 

iframe的调用包括以下几个方面:(调用包含html dom,js全局变量,js方法)

主页面调用iframe;

iframe页面调用主页面;

主页面的包含的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进行操作;

 

源码

main.html

?
<!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 = "http://www.cnblogs.com/http://www.cnblogs.com/scripts/jquery-1.7.1.min.js"  type = "text/javascript" ></ script >
< script  type = "text/javascript" >
     var gg="dsafdsafdsafdsafsdaf";
     function ggMM() {
         alert("2222222222222222222222222222222");
     }
     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 >

frame.htm

?
<!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 = "http://www.cnblogs.com/http://www.cnblogs.com/scripts/jquery-1.7.1.min.js"  type = "text/javascript" ></ script >
< script  type = "text/javascript" >
 
var ff="adfdasfdsafdsafdsaf";
function test() {
     alert($("#dd").val());
}
function callMainField() {
     alert(parent.gg);
}
function callMainMethod() {
     parent.ggMM();
}
function callMainHtml() {
     alert(parent.$("#ii").attr("id"));
}
function getParameter() {
     alert(window.hellobaby);
}
</ script >
</ head >
< body >
     < a  href = "#"  onClick = "getParameter();" >接受参数</ a >
     < a  href = "#"  onClick = "callMainMethod();" >调用子iframe方法</ a >
     < a  href = "#"  onClick = "callMainField();" >调用主窗口变量</ a >
     < a  href = "#"  onClick = "callMainHtml();" >调用子iframe组件</ a >  
     < input  id = "dd"  type = "text"  value = "1111111111" />
</ body >
</ html >

 兄弟iframe页面 newIframe.htm

复制代码
<!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="http://www.cnblogs.com/http://www.cnblogs.com/scripts/jquery-1.7.1.min.js" type="text/javascript"></script>
<script type="text/javascript">
function callLevelFrame() {
    var ff=parent.$("#ii")[0].contentWindow.ff;
    alert(ff);
}
</script>
</head>
<body>
    <a href="#" onClick="callLevelFrame();">调用兄弟iframe</a>    
    <input id="nn" type="text" value="sdafsdfsa"/>
</body>
</html>
复制代码

 

结语:

我对jquery html css的理解还需要很多提高,自己总结的东西对大牛来说也很幼稚,但大牛之路都是如此总结向上提高的,我不怕这种幼稚。

 

 

 
 
分类:  前端

js调用父框架函数与弹窗调用父页面函数的方法

调用父级中的 aaa的函数


子页面中:

onclick="window.parent.frames.aaa()"

父页面中:

function aaa()
{
alert(‘bbbbb’);
}

----------------------------------------------

frame框架里的页面要改其他同框架下的页面或父框架的页面就用parent
window.opener引用的是window.open打开的页面的父页面。

window.frames对象可以引用iframe里的页面,也可以引用frameset里的页面.

可以这样
window.frames[0].document.getElementById(‘xx’);
可以这样
window.frames[0].document.body.innerHTML;

frm = window.parent.window.frames[‘uploadFrame’];
frmDocument = frm.document;
frm.sb(3); //sb 是uploadFrame页面里的一个函数

对于firefox
如果你遇到报错:parent.document.frames has no properties
换为如下代码就可以了,这个代码IE,ff兼容. frm = window.parent.window.frames[‘uploadFrame’];其实 frames 集合并不是挂在 document 而是挂在 window 对象下.

注意这样修改frame里的页面有限制,就是必须是同域下的,否则无法访问
如果是同一域下,但是子域名不同,那么涉及到的js,html文件都加上一句。
document.domain = xxx.com [这里填写你的域名]

document.getElementById(‘iframeid’).contentWindow.document.getElementById(‘someelementid’);

js弹窗页面后调用父页面函数

(例如:调用父页面函数test2())
window.opener.test2();

框架子页面调用上一个页面方法

(例如:上一页面的框架frame名为menuBar,调用onhook()函数)
window.top.frames["menuBar"].onhook();

js弹窗页面调用父页面框架子页面函数

(如:弹窗页面调用,frame名为menuBar)
window.opener.top.frames['menuBar'].onhook();

你可能感兴趣的:(iframe,contentWindow,parent)