Devo scaricare un file di dati di grandi dimensioni (> 100 MB) tramite XmlHttpRequest
. I dati provengono da una terza parte e vorrei mostrare il contenuto gradualmente man mano che viene scaricato.Accesso ai dati già scaricati
Così ho pensato che il seguente dovrebbe funzionare:
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);
}
Purtroppo, secondo le specifiche, .response
non è disponibile.
C'è un modo per accedere ai dati già scaricati senza andare a soluzioni orribili del genere come l'utilizzo di Flash
?
EDIT:
trovato almeno una soluzione non standard di lavoro per Firefox:
responseType = "moz-chunked-arraybuffer";
Vedi anche: WebKit equivalent to Firefox's "moz-chunked-arraybuffer" xhr responseType
Aspetta, vuoi inviare 100MB al mio browser ?! Quale potrebbe essere sul mio telefono? – DOK
@DOK Confido che tu sia abbastanza intelligente da non chiamare un sito web intensivo per la larghezza di banda e il calcolo sul nostro telefono. – abergmeier
Hai provato a utilizzare req.responseText? – JamieJag