js iframe的onload事件不去作用的原因及解决办法

WBOY
풀어 주다: 2016-06-01 09:54:45
원래의
2592명이 탐색했습니다.

通过createElement_x_x创建的iframe的onload事件在有些时候不响应,具体原因和解决办法如下。

首先,我们来看一下下面这种方法:

<code class="language-javascript">function createFrame(){ 
    var frame = document.cerateElement("iframe");
    frame.onload = function(){alert("loaded - createFrame");}
    frame.src = "http://www.phper.org.cn";
    document.body.a(frame);

}</code>
로그인 후 복사

这一段在FF下是完全如我们所想,能够达到预期效果,但是在IE下面似乎就失效了,导致这种结果的原因还不是十分清楚,有一种说法是IE在检测到 iframe的时候,就把认为它已经装载完成了,通过createElement_x_x创建的iframe,似乎在创建的一瞬间它的onload就完成了,后面的onload设定大概也就无效了。

下面我们再来看一个方法:

<code class="language-javascript">function includeFrame(){
   var div = document.create_rElement_x("div");
   div.innerHTML = "<iframe onload="\"javascript:alert('loaded" src="%5C%22http://www.manongjc.com%5C%22"></iframe>";

   document.body.a(div);
}</code>
로그인 후 복사

这个方法在IE和FF下面测试都通过,上面的那种说法虽然不是很有根据,但是目前还没有找到更好的解释。如果真的是如上面所说的话,那通过第二种方法正好可以解决,因为在第二种方法中iframe的onload事件跳过createElement_x_x("iframe")这个步骤,避免了IE的检测。

onload必须在src前面才可以.

관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
최신 이슈
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿
회사 소개 부인 성명 Sitemap
PHP 중국어 웹사이트:공공복지 온라인 PHP 교육,PHP 학습자의 빠른 성장을 도와주세요!