明天的明天 永远的永远 未知的一切 我与你一起承担 ??

是非成败转头空 青山依旧在 几度夕阳红 。。。
  博客园  :: 首页  :: 管理

JS操作iframe

Posted on 2013-10-30 22:20  且行且思  阅读(594)  评论(0编辑  收藏  举报

1. 获得iframe的window对象

存在跨域访问限制。

chrome:iframeElement. contentWindow
firefox: iframeElement.contentWindow
ie6:iframeElement.contentWindow

文章Iframes, onload, and document.domain中说“he iframe element object has a property called contentDocument that contains the iframe’s document object, so you can use the parentWindow property to retrieve the window object.”意思就是一些浏览器可以通过iframeElement.contentDocument.parentWindow获得iframe的window对象。但经过测试firefox、chrome的element.contentDocument对象没有parentWindow属性。

  1. function getIframeWindow(element){         
  2.     return  element.contentWindow;   
  3.     //return  element.contentWindow || element.contentDocument.parentWindow;   
  4. }  
function getIframeWindow(element){		
    return  element.contentWindow;
    //return  element.contentWindow || element.contentDocument.parentWindow;
}

2. 获得iframe的document对象

存在跨域访问限制。

chrome:iframeElement.contentDocument
firefox:iframeElement.contentDocument
ie:element.contentWindow.document
备注:ie没有iframeElement.contentDocument属性。

  1. var getIframeDocument = function(element) {   
  2.     return  element.contentDocument || element.contentWindow.document;   
  3. };  
var getIframeDocument = function(element) {
    return  element.contentDocument || element.contentWindow.document;
};

3. iframe中获得父页面的window对象

存在跨域访问限制。

父页面:window.parent
顶层页面:window.top
适用于所有浏览器

4. 获得iframe在父页面中的html标签

存在跨域访问限制。

window.frameElement(类型:HTMLElement),适用于所有浏览器

5. iframe的onload事件

非ie浏览器都提供了onload事件。例如下面代码在ie中是不会有弹出框的。

  1. var ifr = document.createElement('iframe');   
  2. ifr.src = 'http://www.b.com/index.php';   
  3. ifr.onload = function() {   
  4.     alert('loaded');   
  5. };   
  6. document.body.appendChild(ifr);  
var ifr = document.createElement('iframe');
ifr.src = 'http://www.b.com/index.php';
ifr.onload = function() {
    alert('loaded');
};
document.body.appendChild(ifr);

但是ie却又似乎提供了onload事件,下面两种方法都会触发onload

  1. 方法一:   
  2. <iframe  onload="alert('loaded');"  src="http://www.b.com/index.php"></iframe>   
  3.   
  4. 方法二:   
  5. //只有ie才支持为createElement传递这样的参数   
  6. var ifr = document.createElement('<iframe  onload="alert('loaded');" src="http://www.b.com/index.php"></iframe>');   
  7. document.body.appendChild(ifr);  
方法一:
<iframe  onload="alert('loaded');"  src="http://www.b.com/index.php"></iframe>

方法二:
//只有ie才支持为createElement传递这样的参数
var ifr = document.createElement('<iframe  onload="alert('loaded');" src="http://www.b.com/index.php"></iframe>');
document.body.appendChild(ifr);

由于iframe元素包含于父级页面中,因此以上方法均不存在跨域问题。

实际上IE提供了onload事件,但必须使用attachEvent进行绑定。

  1. var ifr = document.createElement('iframe');   
  2. ifr.src = 'http://b.a.com/b.php';   
  3. if (ifr.attachEvent) {   
  4.     ifr.attachEvent('onload',  function(){ alert('loaded'); });   
  5. else {   
  6.     ifr.onload  = function() { alert('loaded'); };   
  7. }   
  8. document.body.appendChild(ifr);  
var ifr = document.createElement('iframe');
ifr.src = 'http://b.a.com/b.php';
if (ifr.attachEvent) {
    ifr.attachEvent('onload',  function(){ alert('loaded'); });
} else {
    ifr.onload  = function() { alert('loaded'); };
}
document.body.appendChild(ifr);

6. frames

window.frames可以取到页面中的帧(iframe、frame等),需要注意的是取到的是window对象,而不是HTMLElement。

  1. var ifr1 = document.getElementById('ifr1');   
  2. var ifr1win = window.frames[0];   
  3. ifr1win.frameElement === ifr1;   // true   
  4. ifr1win === ifr1;    // false  

 

//////////////////////////////////////////// 运用 ////////////////////////////////////////////////////////////

      var frames= document.getElementsByTagName("iframe");
            for (var i = 0; i < frames.length; i++) {
            //alert("frameID:" + frames[i].id + "  tabid:" + tabid);
            //var frame=frames[i];           
            }
            */

            //获得iframe的对象fram
            var fram = document.getElementById(tabid);
            //src = params[1];
            //document.fram.location.reload(); //刷新框架内的页面

            //获得iframe的window对象contentWindow,以及js调用iframe内的js函数
            fram.contentWindow.test11(); //test11() 为目标框架内的页面js函数