iframe加载onload之坑

需求:点击按钮,下载一个文件,由于种种原因,需要借助iframe实现。

实现:点击按钮往页面上append一个iframe,将iframe的src设置为文件的url路径,实现下载。如果url不对或文件下载失败,提示下载失败。

畅想:iframe.onload=function(){ //下载成功;}      iframe.onerror = function(){ //下载失败 }

问题:想的挺好,可惜浏览器有意见。经测试,火狐及chorme都不支持onerror事件,而且,不管iframe加载是否成功,都会触发onload事件。

解决:奇技淫巧,通过title来判断页面是否正常加载。

示例:

var url = $this.attr(‘data-url‘);
    $(‘body‘).append(‘<iframe class="down-frame" id="down-frame" width="1" height="1" src="‘+url+‘" ></iframe>‘);
    var downFrame = document.getElementById("down-frame");

    downFrame.onload=function(e){
        var ifDoc = downFrame.contentDocument||{};
        var ifTitle = ifDoc.title;

        if ( ifTitle.indexOf("404")>=0 || ifTitle.indexOf("错误")>=0 ) {
            toastr.error(‘下载失败,请缩小查询范围后重新尝试!‘);
        }
    };

原文地址:https://www.cnblogs.com/newh5/p/9186714.html

时间: 2024-10-27 07:53:46

iframe加载onload之坑的相关文章

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找到了

javscript 实现iframe加载内容页出现LOADING效果

<div id="load" align="center"> <img src="http://sc.cnwebshow.com/upimg/allimg/070707/01294420.gif" /> loading </div> <!-- 首先放一个div,用做loading效果 --> <iframe id="demo" src="http://www.**

转:iframe加载的子页面里面获取父级元素窗口以及元素的高度

iframe里的js要操作父级窗口的dom,必须搞懂几个对象: parent是父窗口(如果窗口是顶级窗口,那么parent==self==top) top是最顶级父窗口(有的窗口中套了好几层frameset或者iframe) self是当前窗口(等价window) 父级页面:index.html <!doctype html> <html> <head> <meta charset="utf-8"> <title>父窗口<

判断iframe加载完成、用于当ifame加载完成时执行一些操作

window.frames["iframec"].addEventListener( "load", function(){ window.frames["iframec"].setFormValue(obj);//iframe加载完成时的操作 }); IE iframe.attachEvent("onreadystatechange", function(){ //此事件在内容没有被载入时候也会被触发,所以我们要判断状态 /

JS iFrame 加载慢怎么解决

在项目中经常要动态添加iframe,然后再对添加的iframe进行相关操作,有时候会遇到iframe加载很慢什么原因呢,该如何解决呢?带着这个问题一起通过本文学习,寻找答案吧! aaa.html <HTML> <HEAD> <TITLE>aaa</TITLE> </HEAD> <BODY> <IFRAME src="bbb.html" name=bbb width="100%" heigh

saiku - 配置spring-security 允许 iframe加载saiku首页

最近提出了一个需求:在一个iframe中展现saiku首页 呵呵,这还不简单. 直接<iframe src="http://localhost:8080/saiku" /> 套进去不就完事了吗..我真是个天才.. 结果:呜呜...报错啦... 错误提示:Refused to display 'http://localhost:8080/saiku/' in a frame because it set 'X-Frame-Options' to 'DENY'. header里

解决iframe加载的内容有时显示有时不显示

在ASP.NET MVC项目中遇到了这样的一个问题,假设父页面有一个iframe <iframe id="sth" src="" scrolling="no" frameborder="0" width="100%" height="100%"></iframe> 通过父页面上的一个按钮触发该iframe的src属性指向一个url: var url = "

页面加载与iframe加载函数

<head> <script> $(document).ready(function(){ alert("a");   var wait = document.getElementById("wait");   if(wait) wait.style.visibility="hidden";   $("iframe").load(function(){ alert("b");    

Razor视图下使用iframe加载RDLC报表

MVC视图下默认是不支持服务器端控件的,所以,为了能够通过report viewer控件加载报表,需要在MVC视图添加嵌入的页面. 起初在stackoverflow上找到一个解决方案,见这里.不过这里的解决方案的一个最大缺陷是,不支持页面导航,也就是只能显示报表的第一页. 因为,原作者也说了,MVC页面下不支持导航控件的post back,也就无法正常工作. 看到评论里有人说iframe才可以解决多页报表的问题,于是试了试,最终成功搞定. 1.在项目中新建立WebForm1.aspx,并修改Gl