iframe 加载外部资源,显示隐藏loading,onload失效

Posted lin_zone

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了iframe 加载外部资源,显示隐藏loading,onload失效相关的知识,希望对你有一定的参考价值。

在项目中使用iframe 来加载外部资源,需要在iframe请求外部资源的时候,需要显示一个loading,在加载完成后,将这个loading隐藏掉,刚开始看到W3C中 iframe有一个 onload事件----该事件在iframe加载资源完成后就会触发,但是这个事件我试了试,发现触发不了,最在https://stackoverflow.com/questions/20572734/load-event-not-firing-when-iframe-is-loaded-in-chrome找到了有效的方法

 

解决办法如下:

1 <iframe class="html_area" src="http://www.baidu.com"></iframe>

设一个变量,var show_loading = true;   //这个变量为真表示loading显示,反之loading隐藏

然后 设一个计时器

var self = this
var html_iframe = document.getElementsByClassName(‘html_area‘)[0]
var interval = setInterval(function () {
    var iframeDoc = html_iframe.contentDocument || html_iframe.contentWindow.document;
    if(iframeDoc.readyState == ‘complete‘ || iframeDoc.readyState == ‘interactive‘){
        self.show_iframe_loading = false
        clearInterval(interval)
    }
},500)

这样在刚开始请求的时候就显示loading,然后启动了计时器,每500ms检测一次,如果iframe内有内容的话,就将loading隐藏了

以上是关于iframe 加载外部资源,显示隐藏loading,onload失效的主要内容,如果未能解决你的问题,请参考以下文章

如果 iframe 无法在 src 加载资源,如何显示替代图像?使用 AngularJs?

使 iFrame 在页面启动时不加载

如何隐藏显示iframe

iframe实现vue嵌套外部系统

动态 iframe 高度取决于隐藏/显示

防止 iframe 内容在 firefox 中隐藏时重新加载