我需要通过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
?
编辑:
找到至少一个适用于 Firefox 的非标准解决方案:
responseType = "moz-chunked-arraybuffer";
另请参阅:WebKit 等效于 Firefox 的“moz-chunked-arraybuffer”xhr responseType