新版本的XMLHttpRequest对象,传送数据的时候,有一个progress事件,用来返回进度信息。
它分成上传和下载两种情况
1)下载的progress事件属于XMLHttpRequest对象
2)上传的progress事件属于XMLHttpRequest.upload对象。
我 们先定义progress事件的回调函数。
xhr.onprogress = updateProgress; xhr.upload.onprogress = updateProgress;
然后,在回调函数里面,使用这个事件的一些属性。
function updateProgress(event) {
if(event.lengthComputable) {
var percentComplete = event.loaded / event.total;
}
}
上面的代码中,event.total是需要传输的总字节,event.loaded是已经传输的字节。如果event.lengthComputable不为真,则event.total等于0。
与progress事件相关的,还有其他五个事件,可以分别指定回调函数:
* load事件:传输成功完成。
* abort事件:传输被用户取消。
* error事件:传输中出现错误。
* loadstart事件:传输开始。
* loadEnd事件:传输结束,但是不知道成功还是失败。
//==========XMLHttpRequest上传文件实现进度条=========
http://www.cnblogs.com/tianyuchen/p/5594641.html
//==========你真的会使用XMLHttpRequest吗?==========
https://segmentfault.com/a/1190000004322487
本文介绍如何利用XMLHttpRequest对象的progress事件来控制文件上传和下载的进度,并提供了具体的代码实例。文章详细解释了progress事件的属性及其用法,还介绍了与之相关的其他五个事件。
1382

被折叠的 条评论
为什么被折叠?



