js操作iframe的那点事
js操作iframe的那点事
现在工作上基本很少去涉及iframe的相关操作,这些自己做个demo来记录学习:看得我有点绕而且晕.
这次要谈到的问题涉及以下三个点:(在同域状态下)
1.父窗体访问子窗体中的某方法或某个元素
2.子窗体访问父窗体中的某方法或某个元素
3.子窗体访问相邻窗体中的方法或某个元素
注意点:在本地直接用IE和FF打开测试正常,但用Chrome直接打开测试无效.原来Chrome不允许采用file:协议引用父窗口,放到Web容器中测试就正常了。
这是父窗体的代码:
总结:父窗体访问子窗体的方法跟元素采用不同的方式
01 02 03 04 05 06 07 08 09 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 | <div class = "line" >====================注意:测试从这里开始=========================</div> <p id= "pox" >用来测试子窗体iframeA访问父窗体的某元素</p> <div class = "line" >====================iframe分割线=========================</div> <iframe src= "iframeA.html" width= "100%" frameborder= "0" id= "frameA" name= "frameA" ></iframe> <iframe src= "iframeB.html" name= "iframeB" width= "100%" frameborder= "0" id= "frameB" ></iframe> <div class = "line" >====================iframe分割线=========================</div> <p>先来演示:父窗体访问子窗体中的某方法或元素</p> <p>总结:父窗体访问子窗体的方法跟元素采用不同的方式</p> <input type= "button" onclick= "frameDiv()" value= "父窗体访问子窗体中的某元素" /> <input type= "button" onclick= "frameFun()" value= "父窗体访问子窗体中的某方法" /> <script type= "text/javascript" > //子窗口访问父窗口方法 function testP(){ alert( "子窗口A访问父窗口的方法" ) } //取得iframe的元素 function getIframe(id){ return document.getElementById(id).contentWindow.document; } //父窗口访问子窗口元素 function frameDiv(){ getIframe( "frameA" ).getElementById( "ooxx" ).style.backgroundColor= "#f00" //window.frames["iframeA"].getElementById("ooxx").style.backgroundColor="#f00" //不能通过这种形式访问某元素 } //父窗口访问子窗口方法 function frameFun(){ //getIframe("frameB").getsFun();//不能通过这种形式访问子窗体某方法 window.frames[ "iframeB" ].getsFun() } </script> |
这是子窗体iframeA的代码:
01 02 03 04 05 06 07 08 09 10 11 12 13 14 15 16 17 18 19 20 | <div id= "ooxx" >用来测试父窗体访问子窗体中的某元素</div> <p id= "divooxx" >用来测试子窗口B访问窗体A的某元素</p> <p>1.子窗口iframeA访问父窗口的某元素</p> <input type= "button" onclick= "frameToPdiv()" value= "子窗口访问父窗口的某元素" /> <input type= "button" onclick= "frameToPfun()" value= "子窗口访问父窗口的某方法" /> <script type= "text/javascript" > //子窗口访问父窗口的某元素 function frameToPdiv(){ parent.document.getElementById( "pox" ).style.color= "#fff" ; parent.document.getElementById( "pox" ).style.backgroundColor= "#f0a0f0" } //子窗口访问父窗口方法 function frameToPfun(){ parent.testP(); } //用于测试iframeB访问的方法 function testBA(){ alert( "用于测试iframeB访问的方法" ) } </script> |
这是子窗体B的代码:
01 02 03 04 05 06 07 08 09 10 11 12 13 14 15 16 17 18 19 20 21 22 23 | <p>二:测试子窗体间相互访问某方法或元素</p> <input type= "button" value= "子窗体B访问子窗体A的某元素" onclick= "frameTframeDiv()" /> <input type= "button" value= "子窗体B访问子窗体A的某方法" onclick= "frameTframeFun()" /> <script type= "text/javascript" > //子窗体B访问子窗体A的某元素 function frameTframeDiv(){ //parent.document.getElementById("frameA").contentWindow.document.getElementById("divooxx").style.color="#a0c0f0"; //parent.document.getElementById("frameA").contentWindow.document.getElementById("divooxx").style.backgroundColor="#000" var _bframe=parent.getIframe( "frameA" ); //子窗体访问父窗体方法 _bframe.getElementById( "divooxx" ).style.color= "#a0c0f0" ; _bframe.getElementById( "divooxx" ).style.backgroundColor= "#000" ; } //子窗体B访问子窗体A的某方法 function frameTframeFun(){ window.parent.frames[ "frameA" ].testBA(); } </script> <script type= "text/javascript" > function getsFun(){ alert( "父窗体访问Bframe子窗体的方法" ) } //getFun() </script> |
好了,代码就那样,重点要了: