js 文件下载 进度条

Posted 【云】风过无痕

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了js 文件下载 进度条相关的知识,希望对你有一定的参考价值。

 

js:

 /**
  * 下载文件 - 带进度监控
  * @param url: 文件请求路径
  * @param name: 保存的文件名
  * @param progress: 进度处理回调函数
* eg: progressDownLoad({url:‘http://loacalhost:8080/downLoad.action‘,‘file.rar‘,progress:function(percent){
* console.log(percent);
* }}); *
*/ function progressDownLoad({url,filename,progress}){ var req = new XMLHttpRequest(); req.open("POST", url, true); //监听进度事件 req.addEventListener("progress", function (evt) { if (evt.lengthComputable) { var percentComplete = evt.loaded / evt.total; if(progress) try{ progress.call(percentComplete); }catch(e){} } }, false); req.responseType = "blob"; req.onreadystatechange = function () { if (req.readyState === 4 && req.status === 200) { if (typeof window.chrome !== ‘undefined‘) { // Chrome version var link = document.createElement(‘a‘); link.href = window.URL.createObjectURL(req.response); link.download = filename; link.click(); } else if (typeof window.navigator.msSaveBlob !== ‘undefined‘) { // IE version var blob = new Blob([req.response], { type: ‘application/force-download‘ }); window.navigator.msSaveBlob(blob, filename); } else { // Firefox version var file = new File([req.response], filename, { type: ‘application/force-download‘ }); window.open(URL.createObjectURL(file)); } } }; req.send(); }

 




以上是关于js 文件下载 进度条的主要内容,如果未能解决你的问题,请参考以下文章

简单的圆形下载进度条

当片段视图加载是异步任务的一部分时,如何在片段加载之前显示进度条?

自定义对话框片段内的进度条 - 如何从 AsyncTask 传递进度?

文件上传和进度条

在recyclerview片段Reandroid中屏幕旋转后进度条不显示

css Bootstrap 3进度条片段