js下载文件,判断文件是否返回

时间: 2019-05-29阅读: 313标签: 文件

下载之前用的window.location.href下载的,但是这个判别不了文件是否返回,小文件倒还好,大的文件长时间没有下载也没有加载条什么的,用户有时会点击下载好几下,大的数据很容易将服务拖垮,所以决定改良下,参考网上大神的,大概思路是:用ifram标签下载,追加到文档,下载完成移除,前端带一个时间戳的cookie,后台接收,下载完成之后返回,前端一个定时循环的函数去验证是不是返回了时间戳,如果是确认下载成功


前端代码:

$("#mylink").click(function () {
	var iframe=document.createElement("iframe");
	//指定iframe的路径
	iframe.src= dss.rootPath + "plugin/sjwfx/NineAddressNoLeisUreExport";
	$(iframe).css("display","none");
	//开始“数据正在加载”的进度条,提示用户在导出数据
	dss.alert("正在为您导出数据,请稍后片刻");
	dss.load(true);
	//追加元素到文档
	document.body.appendChild(iframe);
	//每隔一秒循环下里面代码,如果是我返回的值,关闭加载
	var interval = setInterval(function(){
    //获取返回的cookie
    var down = dss.cookie.get("resultId");
    if(down=="75941785"){
	    //隐藏“数据正在加载”的进度条
	    dss.load(false);
	    $(iframe).remove();
	    //关闭循环的时间函数
	    clearInterval(interval);
    }
	},1000);
});

后台添加这么几行代码:

Cookie cookie=new Cookie("resultId","75941785");//将时间戳设置到cookie中
 cookie.setPath("/");//可能会出现前端js读取不到,所以设置下
cookie.setMaxAge(10);//设置cookie生存时间,可调小一点
response.addCookie(cookie);//添加cookie


我前端没有带上时间戳,因为iframe的关系,我这是iframe嵌在iframe里面的,后台一直读取不到我带的cookie,百度了很多没有很好的解决办法,所以我是直接在后台带上值,前端识别,我是设置了cookie时间为十秒就失效,注意:后台如果配置文件配置了http-only,前端js是不能读取操作的,还有就是setPath不是必须带的,如果前端读取不到,试着带下,或者指定你的项目名。


链接: http://www.fly63.com/article/detial/3479

使用FileSave.js将网页内容保存到文件

在写Chrome extension时候,偶尔需要将网页的内容保存到文件。要实现此功能,正常的流程是创建Blob对象存放内容,创建url,创建一个 a 标签,然后将连接与Blob对象关联并放到 a标签的href或者download(H5)属性中

微信小程序实现pdf,word等格式文件上传

目前微信提供了一个接口 wx.chooseMessageFile 它能让用户从聊天记录里面选择一个或者多个文件,然后返回它的一些信息,列入文件的path地址,文件名,文件的大小等.获取这些信息再结合微信的上传接口wx.uploadFile,即可实现文件上传.

input type=file 上传文件,同一个文件第二次上传无反应

用input file上传文件,掉用onchange方法时,多次上传同一个文件时功能失效,不会发送ajax请求,input[type=file]使用的是onchange去做,onchange监听的为input的value值,只有再内容发生改变的时候去触发

前端工程师也要掌握的几种文件路径知识

之前在做webpack配置时候多次用到路径相关内容,最近在写项目的时候,有一个文件需要上传到阿里云oss的功能,同时本地服务器也需要保留一个文件备份。多次用到了文件路径相关内容以及Node核心API的path模块

在不使用mv命令的情况下移动文件

有时当你需要移动一个文件时,mv 命令似乎不是最佳选项,那么你会如何做呢?不起眼的 mv 命令是在你见过的每个 POSIX 系统中都能找到的有用工具之一。它的作用是明确定义的,并且做得很好

基于Node的Axure文件在线预览

公司现在的产品Axure文档在生成好Html文件之后,都是通过git来进行管理的,每次文件更新,大家都需要从git上进行拉取,然后在本地查看,更新会出现不及时的问题,大家有时候忘记git拉取导致出现实现效果与最终产品稿不一致

Webpack require.context() 前端工程化之动态导入文件

webpack作为前端构建的打包工具, 把各种资源,例如JS(含JSX)、coffee、css(含less/sass)、图片等都作为模块来处理和使用,它已经做了非常好了,它还有非常多的功能等待我们去发掘,研究。

用node.js读写文件

node.js没有二进制数据类型,却提供了类似字节数组的“流“数据类型,着一种数据类型在文件系统模块中频频出现;把文件内容读入缓冲区,并把缓冲区内容解读为utf8模式,(16进制也可以哦)

html5:FileAPI 文件操作实战

HTML5 为我们提供了 File API 相关规范。主要涉及 File 接口 和 FileReader 对象 。本文整理了兼容性检测、文件选择、属性读取、文件读取、进度监控、大文件分片上传以及拖拽上传等开发中常见的前端文件操作。

Node.js之删除文件夹(含递归删除)

应用场景:比如像Eclipse这样的IDE,右击项目,出现选项,点击选项中的删除,就可以删除这个项目及其下的子目录包含文件(使用electron开发的桌面端项目多少都会用到)。

fly63.com版权所有,内容以共享、参考、研究为目的,不存在任何商业目的。其版权属原作者所有,如有侵权,请与小编联系!情况属实本人将予以删除!

广告赞助文章投稿关于web前端网站点搜索站长推荐网站地图站长QQ:522607023

小程序专栏: 土味情话心理测试脑筋急转弯幽默笑话段子句子语录成语大全