Мне нужно загрузить большой (> 100 МБ) файл данных через XmlHttpRequest
. Данные получены от третьей стороны, и я хотел бы постепенно отображать контент по мере его загрузки.Доступ к уже загруженным данным
Так я думал, что следующий будет работать:
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
?
EDIT:
Найдено по крайней мере, рабочий нестандартное решение для Firefox:
responseType = "moz-chunked-arraybuffer";
Смотрите также: WebKit equivalent to Firefox's "moz-chunked-arraybuffer" xhr responseType
Ждут, вы хотите отправить 100MB в мой браузер ?! Что может быть на моем телефоне? – DOK
@ DOK Надеюсь, вы достаточно умны, чтобы не называть интенсивный сайт с пропускной способностью и интенсивным вычислением на нашем телефоне. – abergmeier
Вы пытались использовать req.responseText вместо этого? – JamieJag