我需要通過XmlHttpRequest
下載大量(> 100MB)的數據文件。數據來自第三方,我希望在下載內容時逐漸顯示內容。訪問已下載的數據
所以我想下面將工作:
var req = new XMLHttpRequest();
req.open("GET", mirror.url, true);
req.responseType = "arraybuffer";
req.onload = function(oEvent) {
console.log("DONE");
};
var current_offset = 0;
req.addEventListener("progress", function(event) {
if(event.lengthComputable) {
var percentComplete = Math.round(event.loaded * 100/event.total);
}
var data = req.response;
// Fails here: req.response is null till load is called
var dataView = new DataView(data);
while(current_offset < dataView.byteLength) {
// do work
++current_offset;
}
console.log("OFFSET " + current_offset + " [" + percentComplete + "%]");
}, false);
try {
req.send(null);
} catch(er) {
console.log(er);
}
可悲的是,根據該規範,.response
不可用。
有沒有什麼辦法可以訪問已下載的數據,而不需要像使用Flash
這樣的可怕解決方法?
編輯:
發現至少有一個工作非標準Firefox的解決方案:
responseType = "moz-chunked-arraybuffer";
參見:WebKit equivalent to Firefox's "moz-chunked-arraybuffer" xhr responseType
等等,你想發送100MB到我的瀏覽器?哪些可能在我的手機上? – DOK 2013-03-08 15:17:51
@DOK我相信您足夠聰明,不會在我們的手機上撥打帶寬和計算密集型網站。 – abergmeier 2013-03-08 15:28:22
您是否嘗試過使用req.responseText呢? – JamieJag 2013-03-08 15:30:48