需求:点击按钮,下载一个文件,因为种种缘由,须要借助iframe实现。浏览器
实现:点击按钮往页面上append一个iframe,将iframe的src设置为文件的url路径,实现下载。若是url不对或文件下载失败,提示下载失败。app
畅想:iframe.onload=function(){ //下载成功;} iframe.onerror = function(){ //下载失败 }测试
问题:想的挺好,惋惜浏览器有意见。经测试,火狐及chorme都不支持onerror事件,并且,无论iframe加载是否成功,都会触发onload事件。this
解决:奇技淫巧,经过title来判断页面是否正常加载。url
示例:spa
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('下载失败,请缩小查询范围后从新尝试!'); } };