博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Iframe父页面与子页面之间的调用
阅读量:6206 次
发布时间:2019-06-21

本文共 2056 字,大约阅读时间需要 6 分钟。

Iframe父页面与子页面之间的调用

专业词语解释如下

    Iframe:iframe元素是文档中的文档。

    window对象: 浏览器会在其打开一个HTML文档时创建一个对应的window对象。但是,如果一个文档定义了一个或者多个框架(即:包含一个或者多个frame或者iframe标签),浏览器就会为原始文档创建一个window对象,再为每个iframe创建额外的window对象,这些额外的window对象是原始窗口的子窗口。

contentWindow: 是指指定的iframe或者iframe所在的window对象。

如果想要学习 "iframe之间的通信问题及iframe高度自适应",请看这边文章:

父页面与子页面之间的调用。

现在我们可以慢慢做demo来分别讲解下,假如有iframe父页面为 iframe1.html, 父页面上有2个子页面 分别为iframe2.html 和 iframe3.html。

父页面iframe1.html代码如下:

     
Document
父页面

子页面iframe2.html代码如下:

   
Document
aaa
子页面

1.  子页面iframe2.html调用父页面 iframe1.html的元素如下代码:

console.log($('.iframe1',parent.document));

2. 子页面iframe2.html调用父页面iframe1.html的函数如下代码:

parent.test2();

注意:父页面iframe1.html页面 中test2方法不能放在$(function(){}), 放在里面就调用不到。

3.     子页面iframe2.html调用自身的iframe(假如父页面有很多iframe,获取自身iframe不通过id或者name属性).

       1.  首先我们可以在父页面上写一个函数 用来获取页面所有的iframe,之后进行遍历,进行判断当前的window对象是否相同。如下代码:

function getFrame(f){        var frames = document.getElementsByTagName("iframe");         for(i=0;i

    2. 在子页面iframe2.html中如下调用父页面的方法 getFrame.

       /* 获取自身的iframe */

var aa = parent.getFrame(this); console.log(aa);$(aa).attr("flag",true);

  给iframe2设置属性 flag: true, 如下截图:

  

4.  父页面iframe1.html调用子页面 iframe2.html的元素及函数

    如下调用有误的:

console.log(document.getElementById("iframe2").contentWindow.b());

    因为iframe2.html 有可能未加载完成,所以要等iframe2加载完成后再进行调用,所以我们需要 iframe2.onload = function(){}; 这样再进行调用。为了兼容IE,我们可以如下封装一个方法:

function iframeIsLoad(iframe,callback){        if(iframe.attachEvent) {                  iframe.attachEvent('onload',function(){                     callback && callback();               });         }else {                 iframe.onload = function(){                      callback && callback();                 }         }   }

调用方式如下

// 父页面调用子页面iframe2的方法

var iframe2 = document.getElementById("iframe2");iframeIsLoad(iframe2,function(){       iframe2.contentWindow.b();   // 打印出 我是子页面           // 父页面获取子页面iframe2的元素       var iframeDom = $(".iframe2",iframe2.contentWindow.document);       console.log(iframeDom);});

转载地址:http://wlwja.baihongyu.com/

你可能感兴趣的文章
[leetcode]Construct Binary Tree from Inorder and Postorder Traversal
查看>>
nuget自动发布脚本
查看>>
分享:后台检测U盘并复制到指定路径(C语言实现)
查看>>
js 停止事件冒泡和阻止浏览器默认事件
查看>>
在iPhone应用的导航栏添加自定义标题
查看>>
js练习8(幻灯片切换效果)
查看>>
云计算里AWS和Azure的探究(5) ——EC2和Azure VM磁盘性能分析
查看>>
Android学习笔记23:时间日期控件的使用
查看>>
Oracle日期函数
查看>>
js实现简单网速测试方法
查看>>
SqlServer 扩展属性
查看>>
二分搜索及其扩展
查看>>
switch与ifelse的效率问题
查看>>
Android Intent决议(Intent Resolution)
查看>>
A.4.1-类的继承(implement)
查看>>
hdu 4524(水题)
查看>>
ASP.NET 管理网站(虚拟目录)
查看>>
vs2010 dump 调试
查看>>
每日英语:Hard Math: Adding Up Just How Little We Actually Move
查看>>
hdu 1172(模拟、枚举)
查看>>