在我的项目中,我使用类似以下功能的内容来重定向用户以下载文件
function promptDownload(file){
location.href = "http://example.com/downloads/"+file;
}
众所周知,当我调用此函数时,浏览器只会提示下载对话框,并且不会中断我的应用程序流。我想做的是确定下载完成或取消的时间。
应该有onLoad
,onFinishedLoading
,onConnectionEnd
等等,但我找不到任何内容。
答案 0 :(得分:3)
如果您以这种方式下载文件,则无法确定下载进度。
如果您使用XMLHttpRequest
下载文件,那么您可以监听加载,错误和进度事件,如下所示:
function log(message) {
return function () {
alert(message);
};
}
function download(file, callback) {
var request = new XMLHttpRequest();
request.responseType = 'blob';
request.open('GET', file);
request.addEventListener('load', log('load ' + file));
request.addEventListener('error', log('error ' + file));
request.addEventListener('progress', log('progress ' + file));
request.addEventListener('load', function () {
callback(request.response);
});
request.send();
}
function save(object, mime, name) {
var a = document.createElement('a');
var url = URL.createObjectURL(object);
a.href = url;
a.download = name;
a.click();
}
document.querySelector('#download').addEventListener('click', function () {
download('test.pdf', function (file) {
save(file, 'application/pdf', 'test.pdf');
});
});
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
</head>
<body>
<button id="download">Download</button>
<script src="script.js"></script>
</body>
</html>