关于如何获取iframe中的元素

发表时间
评论 没有

今天研究了一下iframe中元素的获取,发现有些地方还是有点坑的。

首先:如果使用纯前端手段,是没有办法获取非同源的iframe中的元素的,后面会提到后端手段

一、同源环境

  1. 首先在父页面获取iframe中的window,然后获取元素,根据window,不仅可以获取元素,还能调用里面的方法,前提是绑定在window上面
var ifW = $('#ifr')[0].contentWindow;
ifW.document.getElementsByClassName('wrap')
  1. 在iframe中获取父页面的window

window.parent

那么问题来了。这里有些人可能发现,获取元素的时候,根本获取不到,或者有时候有,有时候没有,很奇怪。。。其实呢,这是因为你引入iframe的时候,不能确定iframe是否加载完成,另外具体是iframe里面的js先执行,还是父页面的js先执行,也是个问题。既然问题找到了,那就可以给  

ifW.document.getElementsByClassName('wrap')

这句代码加个延时,或者写在点击事件里面,等点击触发才去获取,这个时候就没有问题了

二、非同源

可以使用 HTML5的api , window.postMessage

在 iframe 里面,向父页面发送消息

window.top.postMessage("close",'*');
  
在父页面,,监听消息

window.addEventListener("message", function(event){
    var origin = event.origin || event.originalEvent.origin;

}, false);

当然也可以在 iframe里面监听事件, 父页面发送消息

来源:https://www.cnblogs.com/muamaker/p/7647021.html

推荐阅读

作者
分类 网站建设, 电脑网络

评论

本文评论功能已关闭。

← 较早的 较新的 →

相关文章