html页面中iframe嵌套页面的父页面和子页面js方法互相调用

﹏ヽ暗。殇╰゛Y 2022-06-09 03:18 628阅读 0赞

我们在写html页面或者说是jsp页面是,有时候需要在一个页面中使用iframe标签嵌套另一个页面,而两个页面有些数据需要交互,这个时候就会用到js技术,互相调用方法,

当我们在父页面中需要调用iframe标签中嵌入的子页面中的js方法时,可以使用:

document.getElementById(iframe的id).contentWindow.childtest();

注:

iframe的id:指的是需要调用的子页面的iframe的id;

childtest():是子页面中的js方法,夫页面就是要调用子页面的这个方法。

当在子页面中需要调用父页面中的方法时,使用如下js:

window.parent.parenttest();

注:

parenttest():是父页面中的js方法。

下面是一个具体的例子:

父页面fatherPage.html代码:

  1. <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
  2. <html xmlns="http://www.w3.org/1999/xhtml" >
  3. <head>
  4. <title>Parent Page</title>
  5. <script language="javascript" type="text/javascript">
  6. function parenttest() {
  7. alert("这是父页面的方法!");
  8. }
  9. function btnClick() {
  10. alert("启动调用子页面的方法");
  11. document.getElementById("childframe").contentWindow.childtest();
  12. }
  13. </script>
  14. </head>
  15. <body>
  16. <div style="margin:auto;">
  17. <h1>This is the Parent Page.</h1>
  18. <input type="button" value="调用子页面的方法" οnclick="btnClick()"/>
  19. </div>
  20. <div style="margin:auto;">
  21. <iframe style="width:300px; height:300px;" id="childframe" src="childPage.html"></iframe>
  22. </div>
  23. </body>
  24. </html>

子页面childPage.html代码:

  1. <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
  2. <html xmlns="http://www.w3.org/1999/xhtml" >
  3. <head>
  4. <title>Child Page</title>
  5. <script language="javascript" type="text/javascript">
  6. function childtest() {
  7. alert("这是子页面的方法!");
  8. }
  9. function btnClick() {
  10. alert("启动调用父页面的方法");
  11. window.parent.parenttest();
  12. }
  13. </script>
  14. </head>
  15. <body>
  16. <div style="margin:auto;">
  17. <h1>This is the Child Page.</h1>
  18. <input type="button" value="调用父页面的方法" οnclick="btnClick()"/>
  19. </div>
  20. </body>
  21. </html>

发表评论

表情:
评论列表 (有 0 条评论,628人围观)

还没有评论,来说两句吧...

相关阅读