XmlHttpRequest的进行时间间隔

我正在使用XmlHttpRequests将图像上传到服务器,并且想向用户显示这些上传的进度。

不幸的是,对我的onprogress-event处理程序的调用之间的间隔太大。对于500k图像,通常仅一次或两次调用onprogress。

这是我的代码:

/* This function is not called often enough */

function progress(e){

console.log('Uploading: ' + Math.round((e.loaded / e.total) * 100) + ' %');

}

var xhr = new XMLHttpRequest();

xhr.upload.addEventListener('progress', progress, false);

xhr.send(data);

可以更改此行为,还是在浏览器实现中将其硬编码?

回答:

W3在其XMLHttpRequest Level

2文档中提出了以下准则。显然,跨浏览器的一致性级别会有所不同。

上载:

当请求实体主体正在上载并且上载完成标志为false时,将任务排队以在XMLHttpRequestUpload对象上大约

触发一个名为progress的进度事件 。-W3

XMLHttpRequest级别2(以粗体显示)

资料下载:

当据说要进行进度通知时,在下载正在进行的同时,将任务排队,以大约 触发一个名为progress的进度事件

。-W3 XMLHttpRequest级别2(以粗体显示)

我不知道可以自定义此功能的API。

以上是 XmlHttpRequest的进行时间间隔 的全部内容, 来源链接: utcz.com/qa/409335.html

回到顶部