我正在尝试使用带有进度表的 HTML5 制作文件上传器。这是我的代码:
<!DOCTYPE html>
<html>
<head>
<title>Test Progress Meter</title>
<script type="text/javascript">
function submitFile(){
var blobOrFile = document.getElementById("fileInput").files[0];
var xhr = new XMLHttpRequest();
xhr.onload = function(e) {
alert("finished!");
};
xhr.upload.onprogress = function(e) {
if (e.lengthComputable) {
document.getElementById("statusBox").innerHTML = e.loaded + " / " + e.total;
}
};
xhr.open('POST', 'test.php', true);
xhr.send(blobOrFile);
};
</script>
</head>
<body>
<input type="file" id="fileInput" onchange="submitFile();" />
Status: <span id="statusBox"></span>
</body>
</html>
基本上,在我所有的浏览器上,当我选择要上传的文件时,进度事件会触发并立即显示整个传输已完成。然后它会在文件实际上传时坐在那里,并且根据文件,在几秒钟/几分钟后,脚本会发出警报并显示来自服务器的正确响应。
我错过了一些明显的东西吗?据我所知,这发生在我所有的浏览器(IE10、Chrome 28、FF22)上。